一个程序中需要进行大量的运算,并且需要在运算过程中支持用户一定的交互,为了获得更好的用户体验,使用BackgroundWorker来完成这一功能.

 
基本操作:
bgw.RunWorkerAsync() :
开始后台运行执行,
该函数后将触发bgw.DoWorker事件,需要执行的操作写在DoWorker事件响应函数里,
该函数也可以加参数,参数从DoWorker事件处理函数的e.Arguement里获取
 
bgw.CancelAsync() :
申请后台程序停止,
注意该函数不能实际停止后台程序,只能将bgw的CancellationPending 值设为true,需要自己在后台运行的程序中判断这一值,进而停止后台程序的运行.
注意本方法使用前,需要将bgw的WorkerSupportsCancellation 值设为true,否则将不起作用.
 
bgw.ReportProgress() :
在后台程序中调用,向主线程传送进度信息,
可以带一个或两个参数,一个为INT类型的进度(0~100),一个为自定义类型的参数,可以传任意信息.
调用后,将触发bgw.ProgressChanged事件,可以将界面变化的代码写在该事件响应函数中,之前提到的两个参数均可从bgw.ProgressChanged事件响应函数的参数e中获取,分别为e.ProgressPercentage和e.UserState.
注意本方法使用前,需要将bgw的WorkerReportsProgress值设为true,否则将不会触发事件.

开始后台运行:
  1. bgw= new BackgroundWorker();
  2. bgw.WorkerSupportsCancellation = true;
  3. bgw.WorkerReportsProgress = true;
  4. bgw.DoWork += new DoWorkEventHandler(bgw_DoWork);
  5. bgw.ProgressChanged += new ProgressChangedEventHandler(bgw_ProgressChanged);
  6. bgw.RunWorkerCompleted += new RunWorkerCompletedEventHandler(bgw_RunWorkerCompleted);
  7. bgw.RunWorkerAsync();
 
DoWork事件处理函数:
  1. void bgw_DoWork(object sender, DoWorkEventArgs e)
  2. {
  3. StartProgress();
  4. }
 
WorkerCompleted事件处理函数(该函数在后台处理完成后被触发)
  1. void bgw_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
  2. {
  3. MessageBox.Show("处理完成");
  4. }
 
ProgressChanged事件处理函数,
  1. void bgw_ProgressChanged(object sender, ProgressChangedEventArgs e)
  2. {
  3. if (e.UserState is int)
  4. {
  5. progressBar1.Value = (int)e.ProgressPercentage;
  6. label2.Text = e.UserState.ToString();
  7. }
  8. else if (e.UserState is List<object>)
  9. {
  10. List<object> tmp = (List<object>)e.UserState;
  11. progressBar1.Value = e.ProgressPercentage;
  12. label2.Text = tmp[0].ToString();
  13. this.label1.Text = tmp[1].ToString();
  14. this.listBox1.Items.Insert(0, tmp[2]);
  15. }
  16. }
 
后台运行的代码
  1. private void StartProgress()
  2. {
  3. //do sth
  4. bgw.ReportProgress(per,paraInt);
  5. }
04-17 14:20