BackgroundWorker的使用

一个程序中需要进行大量的运算,并且需要在运算过程中支持用户一定的交互,为了获得更好的用户体验,使用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,否则将不会触发事件.

开始后台运行:

[csharp] view plaincopyprint?

  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事件处理函数:

[csharp] view plaincopyprint?

  1. void bgw_DoWork(object sender, DoWorkEventArgs e)
  2. {
  3. StartProgress();
  4. }

WorkerCompleted事件处理函数(该函数在后台处理完成后被触发)

[csharp] view plaincopyprint?

  1. void bgw_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
  2. {
  3. MessageBox.Show("处理完成");
  4. }

ProgressChanged事件处理函数,

[csharp] view plaincopyprint?

  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. }

后台运行的代码

[csharp] view plaincopyprint?

  1. private void StartProgress()
  2. {
  3. //do sth
  4. bgw.ReportProgress(per,paraInt);
  5. }

BackgroundWorker的使用

时间: 2024-10-11 07:20:40

BackgroundWorker的使用的相关文章

【翻译】C#中使用BackgroundWorker实现多线程

原文地址:MultiThreading Using a Background Worker, C# 介绍 当开发Windows Forms应用程序时,你会常常注意到:当执行某个耗时的操作,比如处理一个打文件或是从远程服务器请求数据 ,用户界面会进入假死状态.这是由于你的应用程序是运行在单线程下.这个线程负责响应用户界面的操作,同时也负责处理应用程序中所有的事件和方法.因此,耗时的操作会阻塞你的用户界面,直到操作完成.今天,我们将要做的是把这些耗时的操作移到另一个不同的线程中,当以在另一边执行操作

(转)C# 使用BackgroundWorker

本文转载自:http://blog.csdn.net/andrew_wx/article/details/6615077 该例子为使用BackgroundWorker在TextBox文本中产生一个10000以内并且能被5整除的数(1秒产生一个) 操作界面可以启动线程,也可以停止线程,界面设计如图: 先贴代码,有注释的地方就不解释了. 整个Form1窗体代码如下 引入命名空间: using System.Threading; using System.Net; 完整代码: namespace Ba

BackgroundWorker与线程使用

在一个程序中,一些耗时的操作,在长时间运行时可能会导致用户界面 (UI) 处于停止响应状态,用户在这操作期间无法进行其他的操作,为了不使UI层处于停止响应状态,需要将这些耗时的操作,设置为后台线程,并且在UI层可以展示后台操作的进度,比较常用的方法有使用线程以及BackgroundWorker类. 1.线程方法 当我们要在前太展示后台的操作进程时,是不允许跨线程访问控件.此时需要取消控件的跨线程访问,在winform中可以设置CheckForIllegalCrossThreadCalls = f

WPF线程&mdash;&mdash;BackgroundWorker

在WPF中第二个常用的线程处理方式就是BackgroundWorker. 以下是BackgroundWorker一个简单的例子. public partial class MainWindow : Window { /// <summary> /// 后台worker /// </summary> BackgroundWorker worker = new BackgroundWorker(); public MainWindow() { InitializeComponent()

【转】【C#利用后台动态加载数据】Winform&ldquo;防界面卡死&rdquo;【BackgroundWorker】类

using System.ComponentModel 直接使用EgProgressBar方法 BackgroundWorker Bw = new BackgroundWorker(); ListView listView1 = new ListView(); public void EgProgressBar() { DirectoryInfo di = new DirectoryInfo(@"C:/Windows"); FileInfo[] fi = di.GetFiles();

C#.NET中使用BackgroundWorker在模态对话框中显示进度条

这里是一个示例,其中展示了如何使用Backgroundworker对象在模态对话框中显示后台操作的实时进度条. 首先是主窗体代码: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms;

BackgroundWorker源码

BackgroundWorker.cs //------------------------------------------------------------------------------ // <copyright file="BackgroundWorker.cs" company="Microsoft"> // Copyright (c) Microsoft Corporation. All rights reserved. // &l

C# BackgroundWorker 详解

C# BackgroundWorker 详解 在C#程序中,经常会有一些耗时较长的CPU密集型运算,如果直接在 UI 线程执行这样的运算就会出现UI不响应的问题.解决这类问题的主要途径是使用多线程,启动一个后台线程,把运算操作放在这个后台线程中完成.但是原生接口的线程操作有一些难度,如果要更进一步的去完成线程间的通信就会难上加难. 还好 .NET 类库中提供了一个叫做 BackgroundWorker 的类可以比较优雅的解决这类问题.虽然BackgroundWorker 类使用起来比较简单,但其

简单多线程BackgroundWorker

BackgroundWorker是·net里用来执行多线程任务的控件,它允许编程者在一个单独的线程上执行一些操作.在开发多线程程序时,有些时候仅仅只是想实现一个简单的多线程,并不需要写一大堆的委托.回调等等,那么BackgroundWorker便是最好的选择.本Demo演示BackgroundWorker在WPF中的简单线程例子! ---------------------------------------------------------------------XAML代码--------

支持取消操作和暂停操作的Backgroundworker

这也是今天讨论的话题.取消是默认就支持的,而暂停则默认不支持.但通过ManualResetEvent可以对其进行干预. using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using