BackgroundWorker.DoWork BackgroundWorker.DoWork BackgroundWorker.DoWork BackgroundWorker.DoWork Event

Definizione

Si verifica quando viene chiamato il metodo RunWorkerAsync().Occurs when RunWorkerAsync() is called.

public:
 event System::ComponentModel::DoWorkEventHandler ^ DoWork;
public event System.ComponentModel.DoWorkEventHandler DoWork;
member this.DoWork : System.ComponentModel.DoWorkEventHandler 
Public Custom Event DoWork As DoWorkEventHandler 

Esempi

Esempio di codice seguente viene illustrato l'utilizzo del DoWork evento per avviare un'operazione asincrona.The following code example demonstrates the use of the DoWork event to start an asynchronous operation. Questo esempio di codice è parte di un esempio più esaustivo disponibile per il BackgroundWorker classe.This code example is part of a larger example provided for the BackgroundWorker class.

// This event handler is where the actual,
// potentially time-consuming work is done.
void backgroundWorker1_DoWork( Object^ sender, DoWorkEventArgs^ e )
{
   // Get the BackgroundWorker that raised this event.
   BackgroundWorker^ worker = dynamic_cast<BackgroundWorker^>(sender);

   // Assign the result of the computation
   // to the Result property of the DoWorkEventArgs
   // object. This is will be available to the 
   // RunWorkerCompleted eventhandler.
   e->Result = ComputeFibonacci( safe_cast<Int32>(e->Argument), worker, e );
}
// This event handler is where the actual,
// potentially time-consuming work is done.
private void backgroundWorker1_DoWork(object sender, 
    DoWorkEventArgs e)
{   
    // Get the BackgroundWorker that raised this event.
    BackgroundWorker worker = sender as BackgroundWorker;

    // Assign the result of the computation
    // to the Result property of the DoWorkEventArgs
    // object. This is will be available to the 
    // RunWorkerCompleted eventhandler.
    e.Result = ComputeFibonacci((int)e.Argument, worker, e);
}
' This event handler is where the actual work is done.
Private Sub backgroundWorker1_DoWork( _
ByVal sender As Object, _
ByVal e As DoWorkEventArgs) _
Handles backgroundWorker1.DoWork

    ' Get the BackgroundWorker object that raised this event.
    Dim worker As BackgroundWorker = _
        CType(sender, BackgroundWorker)

    ' Assign the result of the computation
    ' to the Result property of the DoWorkEventArgs
    ' object. This is will be available to the 
    ' RunWorkerCompleted eventhandler.
    e.Result = ComputeFibonacci(e.Argument, worker, e)
End Sub 'backgroundWorker1_DoWork

Commenti

Questo evento viene generato quando si chiama il RunWorkerAsync (metodo).This event is raised when you call the RunWorkerAsync method. Ciò avviene quando si avvia l'operazione che esegue le operazioni potrebbe richiedere molto tempo.This is where you start the operation that performs the potentially time-consuming work.

Il codice nel DoWork gestore dell'evento debba verificare periodicamente la CancellationPending valore della proprietà e interrompere l'operazione se si tratta di true.Your code in the DoWork event handler should periodically check the CancellationPending property value and abort the operation if it is true. In questo caso, è possibile impostare il Cancel flag di System.ComponentModel.DoWorkEventArgs a truee il Cancelled flag di System.ComponentModel.RunWorkerCompletedEventArgs nel RunWorkerCompleted gestore dell'evento verrà impostato su true.When this occurs, you can set the Cancel flag of System.ComponentModel.DoWorkEventArgs to true, and the Cancelled flag of System.ComponentModel.RunWorkerCompletedEventArgs in your RunWorkerCompleted event handler will be set to true.

Attenzione

Tenere presente che il codice nel DoWork gestore eventi può terminare la sua attività quando viene effettuata una richiesta di annullamento e il ciclo di polling può impedire CancellationPending viene impostata su true.Be aware that your code in the DoWork event handler may finish its work as a cancellation request is being made, and your polling loop may miss CancellationPending being set to true. In questo caso, il Cancelled flag di System.ComponentModel.RunWorkerCompletedEventArgs nel RunWorkerCompleted gestore dell'evento non verrà impostato true, anche se è stata effettuata una richiesta di annullamento.In this case, the Cancelled flag of System.ComponentModel.RunWorkerCompletedEventArgs in your RunWorkerCompleted event handler will not be set to true, even though a cancellation request was made. Questa situazione viene denominata una race condition e costituisce un problema comune nella programmazione multithreading.This situation is called a race condition and is a common concern in multithreaded programming. Per altre informazioni sulla progettazione multithreading problemi, vedere Threading consigliate gestito.For more information about multithreading design issues, see Managed Threading Best Practices.

Se l'operazione produce un risultato, è possibile assegnare il risultato di DoWorkEventArgs.Result proprietà.If your operation produces a result, you can assign the result to the DoWorkEventArgs.Result property. Questo sarà disponibile per il RunWorkerCompleted gestore dell'evento nel RunWorkerCompletedEventArgs.Result proprietà.This will be available to the RunWorkerCompleted event handler in the RunWorkerCompletedEventArgs.Result property.

Se l'operazione genera un'eccezione che il codice non gestito, il BackgroundWorker intercetta l'eccezione e lo passa nel RunWorkerCompleted gestore eventi, in cui viene esposta come il Error proprietà della System.ComponentModel.RunWorkerCompletedEventArgs.If the operation raises an exception that your code does not handle, the BackgroundWorker catches the exception and passes it into the RunWorkerCompleted event handler, where it is exposed as the Error property of System.ComponentModel.RunWorkerCompletedEventArgs. Se si esegue il debugger di Visual Studio, il debugger si interrompe in corrispondenza del punto nel DoWork gestore dell'evento in cui è stata generata l'eccezione non gestita.If you are running under the Visual Studio debugger, the debugger will break at the point in the DoWork event handler where the unhandled exception was raised. Se si dispone di più di uno BackgroundWorker, è consigliabile non fare riferimento ad esse direttamente, verrebbe le DoWork gestore eventi da un'istanza specifica di BackgroundWorker.If you have more than one BackgroundWorker, you should not reference any of them directly, as this would couple your DoWork event handler to a specific instance of BackgroundWorker. Invece, dovrebbe accedere il BackgroundWorker eseguendo il cast di sender parametro nel DoWork gestore dell'evento.Instead, you should access your BackgroundWorker by casting the sender parameter in your DoWork event handler.

È necessario prestare attenzione a non modificare tutti gli oggetti dell'interfaccia utente nel DoWork gestore dell'evento.You must be careful not to manipulate any user-interface objects in your DoWork event handler. Comunicare invece con l'interfaccia utente tramite il BackgroundWorker gli eventi.Instead, communicate to the user interface through the BackgroundWorker events.

Per altre informazioni su come gestire gli eventi, vedere la gestione e generazione di eventi.For more information about how to handle events, see Handling and Raising Events.

Si applica a

Vedi anche