Cet article a fait l’objet d’une traduction automatique. Pour afficher l’article en anglais, activez la case d’option Anglais. Vous pouvez également afficher le texte anglais dans une fenêtre contextuelle en faisant glisser le pointeur de la souris sur le texte traduit.
Traduction
Anglais

Task.ContinueWith méthode (Action<Task>, TaskContinuationOptions)

 

Date de publication : novembre 2016

Crée une continuation qui s'exécute quand la tâche cible se termine conformément au TaskContinuationOptions spécifié.

Espace de noms:   System.Threading.Tasks
Assembly:  mscorlib (dans mscorlib.dll)

public Task ContinueWith(
	Action<Task> continuationAction,
	TaskContinuationOptions continuationOptions
)

Paramètres

continuationAction
Type: System.Action<Task>

Action à exécuter selon le continuationOptionsspécifié. Quand elle est exécutée, la tâche achevée est passée au délégué en tant qu’argument.

continuationOptions
Type: System.Threading.Tasks.TaskContinuationOptions

Options applicables quand la continuation est planifiée et qui en régissent le comportement. Cela inclut des critères, tels que OnlyOnCanceled, ainsi que des options d'exécution, telles que ExecuteSynchronously.

Valeur de retour

Type: System.Threading.Tasks.Task

Nouvelle Task de continuation.

Exception Condition
ArgumentNullException

Le continuationAction argument est null.

ArgumentOutOfRangeException

Le continuationOptions argument spécifie une valeur non valide pour TaskContinuationOptions.

Retourné Task ne sera pas planifié pour l’exécution jusqu'à ce que la tâche en cours terminée. Si les critères de continuation spécifiés via le continuationOptions paramètre ne sont pas remplies, la tâche de continuation sera annulée au lieu d’être planifiée.

L’exemple suivant montre comment utiliser TaskContinuationOptions pour spécifier qu’une tâche de continuation doit s’exécuter simultanément lorsque l’antécédent est terminée. (Si la tâche spécifiée est déjà terminée au moment où ContinueWith est appelée, synchrones s’exécute sur la thread appelant la méthode ContinueWith.)


public class TaskCounter
{
   private volatile int _count;

   public void Track(Task t)
   {
      if (t == null) throw new ArgumentNullException("t");
      Interlocked.Increment(ref _count);
      t.ContinueWith(ct => Interlocked.Decrement(ref _count), TaskContinuationOptions.ExecuteSynchronously);
   }

   public int NumberOfActiveTasks { get { return _count; } }
}

Plateforme Windows universelle
Disponible depuis 8
.NET Framework
Disponible depuis 4.0
Bibliothèque de classes portable
Pris en charge dans : plateformes .NET portables
Silverlight
Disponible depuis 5.0
Silverlight pour Windows Phone
Disponible depuis 8.0
Windows Phone
Disponible depuis 8.1
Retour au début
Afficher: