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

정의

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 

예제

다음 코드 예제에서는 DoWork 이벤트를 비동기 작업을 시작 합니다.The following code example demonstrates the use of the DoWork event to start an asynchronous operation. 이 코드 예제는에 대해 제공 된 큰 예제의 일부는 BackgroundWorker 클래스입니다.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

설명

이 이벤트는 호출 하는 경우는 RunWorkerAsync 메서드.This event is raised when you call the RunWorkerAsync method. 이 잠재적으로 시간이 오래 걸리는 작업을 수행 하는 작업을 시작 하는 위치입니다.This is where you start the operation that performs the potentially time-consuming work.

코드를 DoWork 이벤트 처리기에서 주기적으로 확인 해야 합니다 CancellationPending 속성 값과 작업이 있으면 중단 true합니다.Your code in the DoWork event handler should periodically check the CancellationPending property value and abort the operation if it is true. 이 문제가 발생 하는 경우 설정할 수 있습니다 합니다 Cancel 의 플래그 System.ComponentModel.DoWorkEventArgstrue, 및 Cancelled 의 플래그 System.ComponentModel.RunWorkerCompletedEventArgs 에서 프로그램 RunWorkerCompleted 이벤트 처리기로 설정 됩니다 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.

주의

주의 하는 코드를 DoWork 이벤트 처리기는 취소 되 고 요청이 폴링 루프를 놓칠 수 작업을 종료할 수 있습니다 CancellationPending 로 설정 되 고 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. 이 경우에 Cancelled 의 플래그 System.ComponentModel.RunWorkerCompletedEventArgs 에서 RunWorkerCompleted 이벤트 처리기 설정 하지 것입니다 true취소가 요청 된 경우에 합니다.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. 이 경우 호출 되는 경합 상태 되 다중 스레드 프로그래밍에서 일반적인 문제입니다.This situation is called a race condition and is a common concern in multithreaded programming. 다중 스레드 디자인에 대 한 자세한 정보에 대 한 문제를 참조 하세요 Managed Threading Best Practices합니다.For more information about multithreading design issues, see Managed Threading Best Practices.

작업에서 결과 생성 하는 경우 결과를 할당할 수 있습니다는 DoWorkEventArgs.Result 속성입니다.If your operation produces a result, you can assign the result to the DoWorkEventArgs.Result property. 이를 사용할 수는 RunWorkerCompleted 이벤트 처리기는 RunWorkerCompletedEventArgs.Result 속성입니다.This will be available to the RunWorkerCompleted event handler in the RunWorkerCompletedEventArgs.Result property.

작업 코드를 처리 하지 않는 경우 예외가 발생 하는 경우는 BackgroundWorker 예외를 catch 하 고에 전달 합니다 RunWorkerCompleted 으로 노출 된 이벤트 처리기를 Error 의 속성 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. Visual Studio 디버거에서 실행 하는 경우 디버거가 시점에서 중단 된 DoWork 처리 되지 않은 예외가 발생 하는 이벤트 처리기입니다.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. 둘 이상 있는 경우 BackgroundWorker, 없습니다 참조 해야 그 중 하나를 직접 결합은이 처럼 하 DoWork 이벤트 처리기의 특정 인스턴스를 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. 대신 액세스 해야 하 BackgroundWorker 캐스팅 하 여는 sender 매개 변수에서에 DoWork 이벤트 처리기입니다.Instead, you should access your BackgroundWorker by casting the sender parameter in your DoWork event handler.

사용자 인터페이스 개체를 조작 하지 않도록 주의 해야 프로그램 DoWork 이벤트 처리기입니다.You must be careful not to manipulate any user-interface objects in your DoWork event handler. 대신, 사용자 인터페이스를 통해 통신 합니다 BackgroundWorker 이벤트입니다.Instead, communicate to the user interface through the BackgroundWorker events.

이벤트를 처리 하는 방법에 대 한 자세한 내용은 참조 하세요. 이벤트 처리 및 발생합니다.For more information about how to handle events, see Handling and Raising Events.

적용 대상

추가 정보