AsyncOperationManager AsyncOperationManager AsyncOperationManager AsyncOperationManager Class

Definition

Stellt Parallelitätsverwaltung für Klassen bereit, die asynchrone Methodenaufrufe unterstützen.Provides concurrency management for classes that support asynchronous method calls. Diese Klasse kann nicht vererbt werden.This class cannot be inherited.

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

Beispiele

Das folgende Codebeispiel veranschaulicht die Verwendung der AsyncOperationManager Klasse, um eine Klasse erstellen, die asynchrone Vorgänge für jedem beliebigen Anwendungsmodell unterstützt.The following code example demonstrates using the AsyncOperationManager class to create a class that supports asynchronous operations for any application model. Es veranschaulicht das implementieren eine Klasse, die überprüft, eine Zahl ein, um zu bestimmen, ob sie eine Primzahl ist.It shows how to implement a class that tests a number to determine whether it is prime. Diese Berechnung kann zeitaufwendig sein, damit es in einem separaten Thread ausgeführt wird.This calculation can be time consuming, so it is done on a separate thread. Ausgeführte Berichte, inkrementelle Ergebnisse und abschlussbenachrichtigungen erfolgt durch die AsyncOperation -Klasse, die stellt sicher, dass die Ereignishandler des Clients auf den richtigen Thread oder Kontext aufgerufen werden.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.

Eine vollständige codeauflistung finden Sie unter Vorgehensweise: Übersicht über ereignisbasierte asynchrone Muster.For a full code listing, see How to: Implement a Component That Supports the Event-based Asynchronous Pattern. Eine vollständige codeauflistung eines Client-Formulars, finden Sie unter Vorgehensweise: Implementieren eines Clients des ereignisbasierten asynchronen Musters.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

Hinweise

Wenn Ihre Klasse, um asynchrones Verhalten entsprechend bereitzustellen muss der Übersicht über ereignisbasierte asynchrone Muster, wird eine Anzahl von Parallelitätsprobleme auftreten.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. Dazu gehört die Anforderung, um sicherzustellen, dass der Ereignishandler aufgerufen werden, auf einem Thread oder Kontext, der für das Anwendungsmodell geeignet ist (z. B. Windows Forms-Anwendungen ASP.NETASP.NET Anwendungen, konsolenanwendungen und So weiter).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). Die AsyncOperationManager bietet eine bequeme Möglichkeit zum Erstellen einer Klasse, die unter allen unterstützten von Anwendungsmodellen ordnungsgemäß ausgeführt werden kann die .NET Framework.NET Framework.The AsyncOperationManager provides a convenient way to create a class that runs properly under all application models supported by the .NET Framework.NET Framework.

Die AsyncOperationManager -Klasse verfügt über eine Methode, CreateOperation, gibt ein System.ComponentModel.AsyncOperation , die verwendet werden kann, um die Dauer eines bestimmten asynchronen Tasks nachzuverfolgen.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. Die System.ComponentModel.AsyncOperation für eine Aufgabe Warnungs-Clients verwendet werden kann, wenn eine Aufgabe abgeschlossen ist.The System.ComponentModel.AsyncOperation for a task can be used to alert clients when a task completes. Sie können auch verwendet werden, um Statusupdates und inkrementelle Ergebnisse bereitstellen, ohne dass den Vorgang beendet.It can also be used to post progress updates and incremental results without terminating the operation.

Weitere Informationen zu asynchrone Klassen implementieren, finden Sie unter Implementieren des ereignisbasierten asynchronen Entwurfsmusters.For more information about implementing asynchronous classes, see Implementing the Event-based Asynchronous Pattern.

Eigenschaften

SynchronizationContext SynchronizationContext SynchronizationContext SynchronizationContext

Ruft den Synchronisierungskontext für den asynchronen Vorgang ab oder legt diesen fest.Gets or sets the synchronization context for the asynchronous operation.

Methoden

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

Gibt für die Überwachung der Dauer eines bestimmten asynchronen Vorgangs eine AsyncOperation zurück.Returns an AsyncOperation for tracking the duration of a particular asynchronous operation.

Gilt für:

Siehe auch