How to use BackgroundWorker in C#

By FoxLearn 11/12/2024 9:20:37 AM   7.44K
The BackgroundWorker class in C# is used for running operations on a separate, dedicated thread in the background, allowing the UI to remain responsive.

When dealing with long-running operations that could cause delays and make your UI unresponsive, the `BackgroundWorker` class offers a convenient solution. It allows you to run tasks in the background on a separate thread, keeping the UI responsive by offloading time-consuming work from the main thread.

Open Visual Studio, then click New Project, then select Visual C# on the left, then Windows and then select Windows Forms Application. Name your project "BackgroundWorkerExample" and then click OK

How to use BackgroundWorker in a simple C# Windows Forms application.

Drag and drop the ProgressBar, Label, Button and BackgroundWorker controls from Visual Studio toolbox onto your form designer, then you can design your form as below.

backgroundworker in c#

Add a click event handler to the button, then handle your code as shown below.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
struct DataParameter
{
    public int Process;
    public int Delay;
}
 
private DataParameter _inputparameter;
 
//This event allows you to report progress to the UI. You can update your progress bar
private void backgroundWorker_ProgressChanged(object sender, ProgressChangedEventArgs e)
{
    progress.Value = e.ProgressPercentage;
    lblPercent.Text = string.Format("Processing...{0}%", e.ProgressPercentage);
    progress.Update();
}
 
//This event is where the background task is executed.
private void backgroundWorker_DoWork(object sender, DoWorkEventArgs e)
{
    //Set parameter
    int process = ((DataParameter)e.Argument).Process;
    int delay = ((DataParameter)e.Argument).Delay;
    int index = 1;
    try
    {
        for (int i = 0; i < process; i++)
        {
            if (!backgroundWorker.CancellationPending)
            {
                backgroundWorker.ReportProgress(index++ * 100 / process, string.Format("Process data {0}", i));
                Thread.Sleep(delay);//used to simulate length of operation
                //Add your code here...
            }
        }
    }
    catch (Exception ex)
    {
        backgroundWorker.CancelAsync();
        MessageBox.Show(ex.Message, "Message", MessageBoxButtons.OK, MessageBoxIcon.Error);
    }
}
 
//This event is triggered when the background task completes.
private void backgroundWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
    MessageBox.Show("Process has been completed.", "Message", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
 
//Run backgroundworker
private void btnStart_Click(object sender, EventArgs e)
{
    if (!backgroundWorker.IsBusy)
    {
        _inputparameter.Delay = 10;
        _inputparameter.Process = 1200;
        backgroundWorker.RunWorkerAsync(_inputparameter);
    }
}
 
private void btnStop_Click(object sender, EventArgs e)
{
    if (backgroundWorker.IsBusy)
        backgroundWorker.CancelAsync();
}

DoWork: The method where the background task is performed. This runs on a separate thread, so it doesn’t block the UI.

RunWorkerCompleted: Triggered when the background task is finished. It runs on the UI thread and can be used to update the UI with the task result or handle cancellation.

ProgressChanged: This event allows for reporting progress during the background operation. You can use it to update UI elements like a progress bar.

Cancellation: The BackgroundWorker class supports cancellation through the CancelAsync() method and checking CancellationPending in the DoWork event handler.

To start the background work with the BackgroundWorker class, you use the RunWorkerAsync() method. This method triggers the execution of the task defined in the DoWork event handler on a separate background thread. Once called, the background operation begins, and you can report progress or handle completion using the relevant events (ProgressChanged and RunWorkerCompleted).

VIDEO TUTORIAL