线程学习10——BackgroundWorker类
BackgroundWorker 类
基本概念
注意:此类在 .NET Framework 2.0 版中是新增的。
BackgroundWorker 类允许您在单独的专用线程上运行操作。
耗时的操作(如下载和数据库事务)在长时间运行时可能会导致用户界面 (UI) 似乎处于停止响应状态。
如果您需要能进行响应的用户界面,而且面临与这类操作相关的长时间延迟,则可以使用 BackgroundWorker 类方便地解决问题。
使用方法:
可以通过编程方式创建 BackgroundWorker,也可以将它从“工具箱”的“组件”选项卡中拖到窗体上。
如果在 Windows 窗体设计器中创建 BackgroundWorker,则它会出现在组件栏中,而且它的属性会显示在“属性”窗口中。
若要设置后台操作,请为 DoWork 事件添加一个事件处理程序。在此事件处理程序中调用耗时的操作。若要启动该操作,请调用 RunWorkerAsync。
若要收到进度更新通知,请对 ProgressChanged 事件进行处理。若要在操作完成时收到通知,请对 RunWorkerCompleted 事件进行处理。
如果后台操作需要参数,请在调用 RunWorkerAsync 时给出参数。在 DoWork 事件处理程序内部,可以从 DoWorkEventArgs.Argument 属性中提取该参数。
注意:您必须非常小心,确保在 DoWork 事件处理程序中不操作任何用户界面对象。而应该通过 ProgressChanged 和 RunWorkerCompleted 事件与用户界面进行通信。
示例如下:

View Code
public struct CalcInput
{
public int x;
public int y;
public CalcInput(int x,int y)
{
this.x = x;
this.y = y;
}
}
View Code
private void OnDoWork(object sender, DoWorkEventArgs e)
{
CalcInput input = (CalcInput)e.Argument;
e.Result = input.x + input.y;
}
private void OnWorkCompleted(object sender, RunWorkerCompletedEventArgs e)
{
this.txtResult.Text = e.Result.ToString();
this.btnCalculate.Enabled = true;
this.btnCancel.Enabled = false;
this.progressBar1.Value = 100;
}
private void btnCalculate_Click(object sender, EventArgs e)
{
this.btnCalculate.Enabled = false;
this.txtResult.Text = String.Empty;
this.btnCancel.Enabled = true;
this.progressBar1.Value = 0;
backgroundWorker1.RunWorkerAsync(new CalcInput(int.Parse(this.txtX.Text), int.Parse(this.txtY.Text)));
backgroundWorker1.DoWork += new DoWorkEventHandler(OnDoWork);
backgroundWorker1.RunWorkerCompleted += new RunWorkerCompletedEventHandler(OnWorkCompleted);
}

浙公网安备 33010602011771号