Freigeben über


AsyncOperationManager Klasse

Definition

Stellt Nebenläufigkeitsverwaltung für Klassen bereit, die asynchrone Methodenaufrufe unterstützen. Diese Klasse kann nicht vererbt werden.

public ref class AsyncOperationManager abstract sealed
public static class AsyncOperationManager
type AsyncOperationManager = class
Public Class AsyncOperationManager
Vererbung
AsyncOperationManager

Beispiele

Das folgende Codebeispiel veranschaulicht die Verwendung der AsyncOperationManager -Klasse zum Erstellen einer Klasse, die asynchrone Vorgänge für jedes Anwendungsmodell unterstützt. Es zeigt, wie eine Klasse implementiert wird, die eine Zahl testet, um zu bestimmen, ob sie prim ist. Diese Berechnung kann zeitaufwändig sein, sodass sie in einem separaten Thread durchgeführt wird. Statusberichte, inkrementelle Ergebnisse und Vervollständigungsbenachrichtigungen werden von der AsyncOperation -Klasse verarbeitet, wodurch sichergestellt wird, dass die Ereignishandler des Clients im richtigen Thread oder Kontext aufgerufen werden.

Eine vollständige Codeauflistung finden Sie unter Vorgehensweise: Implementieren einer Komponente, die das ereignisbasierte asynchrone Muster unterstützt. Eine vollständige Codeauflistung eines Clientformulars finden Sie unter Vorgehensweise: Implementieren eines Clients des ereignisbasierten asynchronen Musters.

// 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

Hinweise

Wenn Ihre Klasse gemäß der Übersicht über ereignisbasierte asynchrone Muster asynchrones Verhalten bereitstellen muss, treten eine Reihe von Problemen bei der Parallelitätsverwaltung auf. Dazu gehört die Anforderung, dass Ereignishandler für einen Thread oder Kontext aufgerufen werden, der für das Anwendungsmodell geeignet ist (z. B. Windows Forms Anwendungen, ASP.NET Anwendungen, Konsolenanwendungen usw.). Bietet AsyncOperationManager eine praktische Möglichkeit zum Erstellen einer Klasse, die ordnungsgemäß unter allen Anwendungsmodellen ausgeführt wird, die vom .NET Framework unterstützt werden.

Die AsyncOperationManager -Klasse verfügt über eine -Methode, CreateOperationdie eine System.ComponentModel.AsyncOperation zurückgibt, die verwendet werden kann, um die Dauer einer bestimmten asynchronen Aufgabe nachzuverfolgen. Der System.ComponentModel.AsyncOperation für einen Task kann verwendet werden, um Clients zu warnen, wenn eine Aufgabe abgeschlossen ist. Es kann auch verwendet werden, um Statusaktualisierungen und inkrementelle Ergebnisse zu veröffentlichen, ohne den Vorgang zu beenden.

Weitere Informationen zum Implementieren asynchroner Klassen finden Sie unter Implementieren des ereignisbasierten asynchronen Musters.

Eigenschaften

SynchronizationContext

Ruft den Synchronisierungskontext für den asynchronen Vorgang ab oder legt diesen fest.

Methoden

CreateOperation(Object)

Gibt für die Überwachung der Dauer eines bestimmten asynchronen Vorgangs eine AsyncOperation zurück.

Gilt für:

Weitere Informationen