How to use BackgroundWorker in C#
By FoxLearn 11/12/2024 9:20:37 AM 7.44K
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.
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
- How to update UI from another thread in C#
- How to Create a Wait Form Dialog in C#
- How to Get all Forms and Open Form with Form Name in C#
- How to Create a custom Progress Bar with Percentage in C#
- How to use Advanced Filter DataGridView in C#
- How to Print DataGridView with Header & Footer with Landscape in C#
- How to Add Combobox to DataGridView in C#
- How to Hide a WinForm in C#