AsyncOperationManager AsyncOperationManager AsyncOperationManager AsyncOperationManager Class

Définition

Fournit la gestion de l'accès concurrentiel pour les classes qui prennent en charge des appels de méthode asynchrone.Provides concurrency management for classes that support asynchronous method calls. Cette classe ne peut pas être héritée.This class cannot be inherited.

public ref class AsyncOperationManager abstract sealed
public static class AsyncOperationManager
type AsyncOperationManager = class
Public Class AsyncOperationManager
Héritage
AsyncOperationManagerAsyncOperationManagerAsyncOperationManagerAsyncOperationManager

Exemples

L’exemple de code suivant illustre l' AsyncOperationManager utilisation de la classe pour créer une classe qui prend en charge les opérations asynchrones pour n’importe quel modèle d’application.The following code example demonstrates using the AsyncOperationManager class to create a class that supports asynchronous operations for any application model. Il montre comment implémenter une classe qui teste un nombre pour déterminer s’il est premier.It shows how to implement a class that tests a number to determine whether it is prime. Ce calcul peut prendre du temps, il est donc effectué sur un thread distinct.This calculation can be time consuming, so it is done on a separate thread. Les rapports de progression, les résultats incrémentiels et les notifications de AsyncOperation fin sont gérés par la classe, ce qui garantit que les gestionnaires d’événements du client sont appelés sur le thread ou le contexte approprié.Progress reports, incremental results, and completion notifications are handled by the AsyncOperation class, which ensures that the client's event handlers are called on the proper thread or context.

Pour obtenir la liste complète de code, consultez Comment : implémenter un composant qui prend en charge le modèle asynchrone basé sur événement.For a full code listing, see How to: Implement a Component That Supports the Event-based Asynchronous Pattern. Pour obtenir la liste complète du code d’un formulaire client , consultez Procédure: implémenter un client du modèle asynchrone basé sur des événements.For a full code listing of a client form, see How to: Implement a Client of the Event-based Asynchronous Pattern.

// This method starts an asynchronous calculation. 
// First, it checks the supplied task ID for uniqueness.
// If taskId is unique, it creates a new WorkerEventHandler 
// and calls its BeginInvoke method to start the calculation.
public virtual void CalculatePrimeAsync(
    int numberToTest,
    object taskId)
{
    // Create an AsyncOperation for taskId.
    AsyncOperation asyncOp =
        AsyncOperationManager.CreateOperation(taskId);

    // Multiple threads will access the task dictionary,
    // so it must be locked to serialize access.
    lock (userStateToLifetime.SyncRoot)
    {
        if (userStateToLifetime.Contains(taskId))
        {
            throw new ArgumentException(
                "Task ID parameter must be unique", 
                "taskId");
        }

        userStateToLifetime[taskId] = asyncOp;
    }

    // Start the asynchronous operation.
    WorkerEventHandler workerDelegate = new WorkerEventHandler(CalculateWorker);
    workerDelegate.BeginInvoke(
        numberToTest,
        asyncOp,
        null,
        null);
}
' This method starts an asynchronous calculation. 
' First, it checks the supplied task ID for uniqueness.
' If taskId is unique, it creates a new WorkerEventHandler 
' and calls its BeginInvoke method to start the calculation.
Public Overridable Sub CalculatePrimeAsync( _
    ByVal numberToTest As Integer, _
    ByVal taskId As Object)

    ' Create an AsyncOperation for taskId.
    Dim asyncOp As AsyncOperation = _
        AsyncOperationManager.CreateOperation(taskId)

    ' Multiple threads will access the task dictionary,
    ' so it must be locked to serialize access.
    SyncLock userStateToLifetime.SyncRoot
        If userStateToLifetime.Contains(taskId) Then
            Throw New ArgumentException( _
                "Task ID parameter must be unique", _
                "taskId")
        End If

        userStateToLifetime(taskId) = asyncOp
    End SyncLock

    ' Start the asynchronous operation.
    Dim workerDelegate As New WorkerEventHandler( _
        AddressOf CalculateWorker)

    workerDelegate.BeginInvoke( _
        numberToTest, _
        asyncOp, _
        Nothing, _
        Nothing)

End Sub

Remarques

Si votre classe doit fournir un comportement asynchrone en fonction de la vue d’ensemble du modèle asynchrone basésur les événements, vous rencontrerez un certain nombre de problèmes de gestion de la concurrence.If your class needs to provide asynchronous behavior according to the Event-based Asynchronous Pattern Overview, you will encounter a number of concurrency management issues. Parmi celles-ci, il est nécessaire de s’assurer que les gestionnaires d’événements sont appelés sur un thread ou un contexte approprié pour le modèle d’application (par ASP.NETASP.NET exemple, les applications de Windows Forms, les applications, les applications de console, etc.).Among these is the requirement to ensure that event handlers are called on a thread or context that is appropriate for the application model (for example, Windows Forms applications, ASP.NETASP.NET applications, console applications, and so on). Le AsyncOperationManager offre un moyen pratique de créer une classe qui s’exécute correctement sous tous les modèles d’application .NET Framework.NET Frameworkpris en charge par le.The AsyncOperationManager provides a convenient way to create a class that runs properly under all application models supported by the .NET Framework.NET Framework.

La AsyncOperationManager classe possède une méthode, CreateOperation, qui retourne un System.ComponentModel.AsyncOperation qui peut être utilisé pour effectuer le suivi de la durée d’une tâche asynchrone particulière.The AsyncOperationManager class has one method, CreateOperation, which returns an System.ComponentModel.AsyncOperation that can be used to track the duration of a particular asynchronous task. Le System.ComponentModel.AsyncOperation d’une tâche peut être utilisé pour alerter les clients lorsqu’une tâche se termine.The System.ComponentModel.AsyncOperation for a task can be used to alert clients when a task completes. Il peut également être utilisé pour envoyer des mises à jour de progression et des résultats incrémentiels sans terminer l’opération.It can also be used to post progress updates and incremental results without terminating the operation.

Pour plus d’informations sur l’implémentation de classes asynchrones, consultez implémentation du modèle asynchrone basé sur les événements.For more information about implementing asynchronous classes, see Implementing the Event-based Asynchronous Pattern.

Propriétés

SynchronizationContext SynchronizationContext SynchronizationContext SynchronizationContext

Obtient ou définit le contexte de synchronisation pour l'opération asynchrone.Gets or sets the synchronization context for the asynchronous operation.

Méthodes

CreateOperation(Object) CreateOperation(Object) CreateOperation(Object) CreateOperation(Object)

Retourne AsyncOperation permettant de suivre la durée d'une opération asynchrone particulière.Returns an AsyncOperation for tracking the duration of a particular asynchronous operation.

S’applique à

Voir aussi