BackgroundWorker
Winfrom程序经常会有一些后台耗时操作,例如批量处理,如果在主UI线程上执行,UI线程会卡死,用户的使用感觉会很差。
而BackgroundWorker
提供了执行异步操作,配合ProgressBarControl
进度条控件,用户能直观看到当前进度,主UI线程也不会等待卡死。
使用总结
-
WorkerReportsProgress
属性
指示BackgroundWorker
是否可以报告进度更新。当该属性值为True是,将可以成功调用ReportProgress
方法 -
WorkerSupportsCancellation
属性
指示BackgroundWorker
是否支持异步取消操作。当该属性值为True是,将可以成功调用CancelAsync
方法 -
CancellationPending
属性
指示应用程序是否已请求取消后台操作。此属性通常放在用户执行的异步操作内部,用来判断用户是否取消执行异步操作。
private void Do_Work(object sender, DoWorkEventArgs e)
{
for (int i = 0; i < 100; i++)
{
if (bgWorker.CancellationPending)
{
// 取消操作
e.Cancel = true;
return;
}
// 模拟后台执行操作
Thread.Sleep(1000);
bgWorker.ReportProgress(i, "success");
}
}
IsBusy
属性
指示BackgroundWorker
是否正在执行一个异步操作。此属性通常放在BackgroundWorker.RunWorkerAsync()
方法之前,避免多次调用RunWorkerAsync()
方法引发异常。
//
if (bgWorker.IsBusy)
{
//避免多次调用
return;
}
this.bgWorker.RunWorkerAsync();
-
DoWork
事件
RunWorkerAsync
后触发,耗时操作放在这里 -
ProgressChanged
事件
bgWorker.ReportProgress()
执行后触发 -
RunWorkerCompleted
事件
DoWork
全部完成或者取消后触发