Task Class
Definition
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Represents an asynchronous operation.
public ref class Task : IAsyncResult
public ref class Task : IAsyncResult, IDisposable
public class Task : IAsyncResult
public class Task : IAsyncResult, IDisposable
type Task = class
interface IAsyncResult
type Task = class
interface IAsyncResult
interface IDisposable
Public Class Task
Implements IAsyncResult
Public Class Task
Implements IAsyncResult, IDisposable
- Inheritance
-
Task
- Derived
- Implements
Remarks
For more information about this API, see Supplemental API remarks for Task.
Constructors
Task(Action) |
Initializes a new Task with the specified action. |
Task(Action, CancellationToken) |
Initializes a new Task with the specified action and CancellationToken. |
Task(Action, CancellationToken, TaskCreationOptions) |
Initializes a new Task with the specified action and creation options. |
Task(Action, TaskCreationOptions) |
Initializes a new Task with the specified action and creation options. |
Task(Action<Object>, Object) |
Initializes a new Task with the specified action and state. |
Task(Action<Object>, Object, CancellationToken) |
Initializes a new Task with the specified action, state, and CancellationToken. |
Task(Action<Object>, Object, CancellationToken, TaskCreationOptions) |
Initializes a new Task with the specified action, state, and options. |
Task(Action<Object>, Object, TaskCreationOptions) |
Initializes a new Task with the specified action, state, and options. |
Properties
AsyncState |
Gets the state object supplied when the Task was created, or null if none was supplied. |
CompletedTask |
Gets a task that has already completed successfully. |
CreationOptions |
Gets the TaskCreationOptions used to create this task. |
CurrentId |
Returns the ID of the currently executing Task. |
Exception |
Gets the AggregateException that caused the Task to end prematurely. If the Task completed successfully or has not yet thrown any exceptions, this will return |
Factory |
Provides access to factory methods for creating and configuring Task and Task<TResult> instances. |
Id |
Gets an ID for this Task instance. |
IsCanceled |
Gets whether this Task instance has completed execution due to being canceled. |
IsCompleted |
Gets a value that indicates whether the task has completed. |
IsCompletedSuccessfully |
Gets whether the task ran to completion. |
IsFaulted |
Gets whether the Task completed due to an unhandled exception. |
Status |
Gets the TaskStatus of this task. |
Methods
ConfigureAwait(Boolean) |
Configures an awaiter used to await this Task. |
ConfigureAwait(ConfigureAwaitOptions) |
Configures an awaiter used to await this Task. |
ContinueWith(Action<Task,Object>, Object) |
Creates a continuation that receives caller-supplied state information and executes when the target Task completes. |
ContinueWith(Action<Task,Object>, Object, CancellationToken) |
Creates a continuation that receives caller-supplied state information and a cancellation token and that executes asynchronously when the target Task completes. |
ContinueWith(Action<Task,Object>, Object, CancellationToken, TaskContinuationOptions, TaskScheduler) |
Creates a continuation that receives caller-supplied state information and a cancellation token and that executes when the target Task completes. The continuation executes based on a set of specified conditions and uses a specified scheduler. |
ContinueWith(Action<Task,Object>, Object, TaskContinuationOptions) |
Creates a continuation that receives caller-supplied state information and executes when the target Task completes. The continuation executes based on a set of specified conditions. |
ContinueWith(Action<Task,Object>, Object, TaskScheduler) |
Creates a continuation that receives caller-supplied state information and executes asynchronously when the target Task completes. The continuation uses a specified scheduler. |
ContinueWith(Action<Task>) |
Creates a continuation that executes asynchronously when the target Task completes. |
ContinueWith(Action<Task>, CancellationToken) |
Creates a continuation that receives a cancellation token and executes asynchronously when the target Task completes. |
ContinueWith(Action<Task>, CancellationToken, TaskContinuationOptions, TaskScheduler) |
Creates a continuation that executes when the target task competes according to the specified TaskContinuationOptions. The continuation receives a cancellation token and uses a specified scheduler. |
ContinueWith(Action<Task>, TaskContinuationOptions) |
Creates a continuation that executes when the target task completes according to the specified TaskContinuationOptions. |
ContinueWith(Action<Task>, TaskScheduler) |
Creates a continuation that executes asynchronously when the target Task completes. The continuation uses a specified scheduler. |
ContinueWith<TResult>(Func<Task,Object,TResult>, Object) |
Creates a continuation that receives caller-supplied state information and executes asynchronously when the target Task completes and returns a value. |
ContinueWith<TResult>(Func<Task,Object,TResult>, Object, CancellationToken) |
Creates a continuation that executes asynchronously when the target Task completes and returns a value. The continuation receives caller-supplied state information and a cancellation token. |
ContinueWith<TResult>(Func<Task,Object,TResult>, Object, CancellationToken, TaskContinuationOptions, TaskScheduler) |
Creates a continuation that executes based on the specified task continuation options when the target Task completes and returns a value. The continuation receives caller-supplied state information and a cancellation token and uses the specified scheduler. |
ContinueWith<TResult>(Func<Task,Object,TResult>, Object, TaskContinuationOptions) |
Creates a continuation that executes based on the specified task continuation options when the target Task completes. The continuation receives caller-supplied state information. |
ContinueWith<TResult>(Func<Task,Object,TResult>, Object, TaskScheduler) |
Creates a continuation that executes asynchronously when the target Task completes. The continuation receives caller-supplied state information and uses a specified scheduler. |
ContinueWith<TResult>(Func<Task,TResult>) |
Creates a continuation that executes asynchronously when the target Task<TResult> completes and returns a value. |
ContinueWith<TResult>(Func<Task,TResult>, CancellationToken) |
Creates a continuation that executes asynchronously when the target Task completes and returns a value. The continuation receives a cancellation token. |
ContinueWith<TResult>(Func<Task,TResult>, CancellationToken, TaskContinuationOptions, TaskScheduler) |
Creates a continuation that executes according to the specified continuation options and returns a value. The continuation is passed a cancellation token and uses a specified scheduler. |
ContinueWith<TResult>(Func<Task,TResult>, TaskContinuationOptions) |
Creates a continuation that executes according to the specified continuation options and returns a value. |
ContinueWith<TResult>(Func<Task,TResult>, TaskScheduler) |
Creates a continuation that executes asynchronously when the target Task completes and returns a value. The continuation uses a specified scheduler. |
Delay(Int32) |
Creates a task that completes after a specified number of milliseconds. |
Delay(Int32, CancellationToken) |
Creates a cancellable task that completes after a specified number of milliseconds. |
Delay(TimeSpan) |
Creates a task that completes after a specified time interval. |
Delay(TimeSpan, CancellationToken) |
Creates a cancellable task that completes after a specified time interval. |
Delay(TimeSpan, TimeProvider) |
Creates a task that completes after a specified time interval. |
Delay(TimeSpan, TimeProvider, CancellationToken) |
Creates a cancellable task that completes after a specified time interval. |
Dispose() |
Releases all resources used by the current instance of the Task class. |
Dispose(Boolean) |
Disposes the Task, releasing all of its unmanaged resources. |
Equals(Object) |
Determines whether the specified object is equal to the current object. (Inherited from Object) |
FromCanceled(CancellationToken) |
Creates a Task that's completed due to cancellation with a specified cancellation token. |
FromCanceled<TResult>(CancellationToken) |
Creates a Task<TResult> that's completed due to cancellation with a specified cancellation token. |
FromException(Exception) |
Creates a Task that has completed with a specified exception. |
FromException<TResult>(Exception) |
Creates a Task<TResult> that's completed with a specified exception. |
FromResult<TResult>(TResult) |
Creates a Task<TResult> that's completed successfully with the specified result. |
GetAwaiter() |
Gets an awaiter used to await this Task. |
GetHashCode() |
Serves as the default hash function. (Inherited from Object) |
GetType() |
Gets the Type of the current instance. (Inherited from Object) |
MemberwiseClone() |
Creates a shallow copy of the current Object. (Inherited from Object) |
Run(Action) |
Queues the specified work to run on the thread pool and returns a Task object that represents that work. |
Run(Action, CancellationToken) |
Queues the specified work to run on the thread pool and returns a Task object that represents that work. A cancellation token allows the work to be cancelled if it has not yet started. |
Run(Func<Task>) |
Queues the specified work to run on the thread pool and returns a proxy for the task returned by |
Run(Func<Task>, CancellationToken) |
Queues the specified work to run on the thread pool and returns a proxy for the task returned by |
Run<TResult>(Func<Task<TResult>>) |
Queues the specified work to run on the thread pool and returns a proxy for the |
Run<TResult>(Func<Task<TResult>>, CancellationToken) |
Queues the specified work to run on the thread pool and returns a proxy for the |
Run<TResult>(Func<TResult>) |
Queues the specified work to run on the thread pool and returns a Task<TResult> object that represents that work. A cancellation token allows the work to be cancelled if it has not yet started. |
Run<TResult>(Func<TResult>, CancellationToken) |
Queues the specified work to run on the thread pool and returns a |
RunSynchronously() |
Runs the Task synchronously on the current TaskScheduler. |
RunSynchronously(TaskScheduler) |
Runs the Task synchronously on the TaskScheduler provided. |
Start() |
Starts the Task, scheduling it for execution to the current TaskScheduler. |
Start(TaskScheduler) |
Starts the Task, scheduling it for execution to the specified TaskScheduler. |
ToString() |
Returns a string that represents the current object. (Inherited from Object) |
Wait() |
Waits for the Task to complete execution. |
Wait(CancellationToken) |
Waits for the Task to complete execution. The wait terminates if a cancellation token is canceled before the task completes. |
Wait(Int32) |
Waits for the Task to complete execution within a specified number of milliseconds. |
Wait(Int32, CancellationToken) |
Waits for the Task to complete execution. The wait terminates if a timeout interval elapses or a cancellation token is canceled before the task completes. |
Wait(TimeSpan) |
Waits for the Task to complete execution within a specified time interval. |
Wait(TimeSpan, CancellationToken) |
Waits for the Task to complete execution. |
WaitAll(IEnumerable<Task>, CancellationToken) | |
WaitAll(ReadOnlySpan<Task>) | |
WaitAll(Task[]) |
Waits for all of the provided Task objects to complete execution. |
WaitAll(Task[], CancellationToken) |
Waits for all of the provided Task objects to complete execution unless the wait is cancelled. |
WaitAll(Task[], Int32) |
Waits for all of the provided Task objects to complete execution within a specified number of milliseconds. |
WaitAll(Task[], Int32, CancellationToken) |
Waits for all of the provided Task objects to complete execution within a specified number of milliseconds or until the wait is cancelled. |
WaitAll(Task[], TimeSpan) |
Waits for all of the provided cancellable Task objects to complete execution within a specified time interval. |
WaitAny(Task[]) |
Waits for any of the provided Task objects to complete execution. |
WaitAny(Task[], CancellationToken) |
Waits for any of the provided Task objects to complete execution unless the wait is cancelled. |
WaitAny(Task[], Int32) |
Waits for any of the provided Task objects to complete execution within a specified number of milliseconds. |
WaitAny(Task[], Int32, CancellationToken) |
Waits for any of the provided Task objects to complete execution within a specified number of milliseconds or until a cancellation token is cancelled. |
WaitAny(Task[], TimeSpan) |
Waits for any of the provided Task objects to complete execution within a specified time interval. |
WaitAsync(CancellationToken) |
Gets a Task that will complete when this Task completes or when the specified CancellationToken has cancellation requested. |
WaitAsync(TimeSpan) |
Gets a Task that will complete when this Task completes or when the specified timeout expires. |
WaitAsync(TimeSpan, CancellationToken) |
Gets a Task that will complete when this Task completes, when the specified timeout expires, or when the specified CancellationToken has cancellation requested. |
WaitAsync(TimeSpan, TimeProvider) |
Gets a Task that will complete when this Task completes or when the specified timeout expires. |
WaitAsync(TimeSpan, TimeProvider, CancellationToken) |
Gets a Task that will complete when this Task completes, when the specified timeout expires, or when the specified CancellationToken has cancellation requested. |
WhenAll(IEnumerable<Task>) |
Creates a task that will complete when all of the Task objects in an enumerable collection have completed. |
WhenAll(ReadOnlySpan<Task>) | |
WhenAll(Task[]) |
Creates a task that will complete when all of the Task objects in an array have completed. |
WhenAll<TResult>(IEnumerable<Task<TResult>>) |
Creates a task that will complete when all of the Task<TResult> objects in an enumerable collection have completed. |
WhenAll<TResult>(ReadOnlySpan<Task<TResult>>) | |
WhenAll<TResult>(Task<TResult>[]) |
Creates a task that will complete when all of the Task<TResult> objects in an array have completed. |
WhenAny(IEnumerable<Task>) |
Creates a task that will complete when any of the supplied tasks have completed. |
WhenAny(ReadOnlySpan<Task>) | |
WhenAny(Task, Task) |
Creates a task that will complete when either of the supplied tasks have completed. |
WhenAny(Task[]) |
Creates a task that will complete when any of the supplied tasks have completed. |
WhenAny<TResult>(IEnumerable<Task<TResult>>) |
Creates a task that will complete when any of the supplied tasks have completed. |
WhenAny<TResult>(ReadOnlySpan<Task<TResult>>) | |
WhenAny<TResult>(Task<TResult>, Task<TResult>) |
Creates a task that will complete when either of the supplied tasks have completed. |
WhenAny<TResult>(Task<TResult>[]) |
Creates a task that will complete when any of the supplied tasks have completed. |
WhenEach(IEnumerable<Task>) | |
WhenEach(ReadOnlySpan<Task>) | |
WhenEach(Task[]) | |
WhenEach<TResult>(IEnumerable<Task<TResult>>) | |
WhenEach<TResult>(ReadOnlySpan<Task<TResult>>) | |
WhenEach<TResult>(Task<TResult>[]) | |
Yield() |
Creates an awaitable task that asynchronously yields back to the current context when awaited. |
Explicit Interface Implementations
IAsyncResult.AsyncWaitHandle |
Gets a WaitHandle that can be used to wait for the task to complete. |
IAsyncResult.CompletedSynchronously |
Gets an indication of whether the operation completed synchronously. |
Extension Methods
AsyncWait<TException>(Task) | |
AwaitWithTimeout(Task, TimeSpan) | |
ToApm(Task, AsyncCallback, Object) | |
ToApmEnd(IAsyncResult) | |
ToApmEnd<TResult>(IAsyncResult) | |
Wait(Task, TimeSpan, Action<Exception,TimeSpan,String>, String) | |
WaitForCompletion(Task) | |
WaitForCompletionNoSpin(Task) | |
WaitForCompletionNoSpin(Task, TimeSpan) | |
WaitAsync(Task, TimeSpan, TimeProvider, CancellationToken) | |
DispatcherOperationWait(Task) |
Waits indefinitely for the underlying DispatcherOperation to complete. |
DispatcherOperationWait(Task, TimeSpan) |
Waits for the specified amount of time for the underlying DispatcherOperation to complete. |
IsDispatcherOperationTask(Task) |
Returns a value that indicates whether this Task is associated with a DispatcherOperation. |
AsAsyncAction(Task) |
Returns a Windows Runtime asynchronous action that represents a started task. |
Applies to
Thread Safety
All members of Task, except for Dispose(), are thread-safe and may be used from multiple threads concurrently.
See also
Feedback
https://aka.ms/ContentUserFeedback.
Coming soon: Throughout 2024 we will be phasing out GitHub Issues as the feedback mechanism for content and replacing it with a new feedback system. For more information see:Submit and view feedback for