• .NET BackgroundWorker


    在这里插入图片描述
    这种比begininvoke高级了点,中途可以取消。 当然还有更高级的 EAP、TPL等

    BackgroundWorker 【.net 2.0】可以用于启动后台线程。
    主要的事件及参数: 1.DoWork——当执行BackgroundWorker.RunWorkerAsync方法时会触发该事
    件,并且传递DoWorkEventArgs参数; 2.RunWorkerCompleted——异步操作完成或中途终止会触发该事件。
    如果需要提前终止执行后台操作,可以调用BackgroundWorker.CancelAsync方 法。
    在处理DoWork事件的函数中检测BackgroundWorker.CancellationPending属性是 否为true,如果是true,则表示用户已经取消了异步调用,同时将DoWorkEventA rgs.Cancel属性设为true(传递给处理DoWork事件的函数的第二个参数),这样当退 出异步调用的时候,可以让处理RunWorkerCompleted事件的函数知道是正常退 出还是中途退出。 3.ProgressChanged——操作处理中获得的处理状态变化,通过BackgroundW
    orker.ReportProgress(int)方法触发该事件,并且传递ProgressChangedEventArg s,其中包含了处理的百分比,这个参数在UI界面上设置progressbar控件。
    谷歌搜索
    主要的方法: 1. BackgroundWorker.RunWorkerAsync——“起动”异步调用的方法有两次重
    载RunWorkerAsync(),RunWorkerAsync(object argument),第二个重载提供了一 个参数,可以供异步调用使用。(如果有多个参数要传递怎么办,使用一个类来传 递他们吧)。调用该方法后会触发DoWork事件,并且为处理DoWork事件的函数传 递DoWorkEventArg参数,其中包含了RunWorkerAsync传递的参数。在相应Do Work的处理函数中就可以做具体的复杂操作。 2. BackgroundWorker.ReportProgress——需要在一个冗长的操作中向用户不 断反馈进度,这样的话就可以调用的ReportProgress(int percent),在调用 ReportP rogress 方法时,触发ProgressChanged事件。提供一个在 0 到 100 之间的整数, 它表示后台活动已完成的百分比。你也可以提供任何对象作为第二个参数,允许你 给事件处理程序传递状态信息。作为传递到此过程的 ProgressChangedEventArgs 参数属性,百分比和你自己的对象(如果提供的话)均要被传递到 ProgressChang ed 事件处理程序。这些属性被分别命名为 ProgressPercentage 和 UserState,并 且你的事件处理程序可以以任何需要的方式使用它们。(注意:只有在Background Worker.WorkerReportsProgress属性被设置为true该方法才可用)。 3. BackgroundWorker.CancelAsync——但需要退出异步调用的时候,就调用的这个方法。但是样还不够,因为它仅仅是将BackgroudWorker.CancellationPen ding属性设置为true。你需要在具体的异步调用处理的时候,不断检查Backgroud Worker.CancellationPending是否为true,如果是真的话就退出。(注意:只有在B ackgroundWorker.WorkerSupportsCancellation属性被设置为true该方法才可 用)。
    BackgroundWorker组件 在VS2005中添加了BackgroundWorker组件,该组件在多线程编程方面使用起来 非常方便,然而在开始时由于没有搞清楚它的使用机制,走了不少的弯路,现在把 我在使用它的过程中的经验与诸位分享一下。 BackgroundWorker类中主要用到的有这列属性、方法和事件: 重要属性: 1、CancellationPending
    获取一个值,指示应用程序是否已请求取消后台
    操作。通过在DoWork事件中判断CancellationPending属性可以认定是否需要取消 后台操作(也就是结束线程); 2、IsBusy
    获取一个值,指示 BackgroundWorker 是否正在运行异
    步操作。程序中使用IsBusy属性用来确定后台操作是否正在使用中; 3、WorkerReportsProgress 获取或设置一个值,该值指示BackgroundWo
    rker能否报告进度更新 4、WorkerSupportsCancellation 获取或设置一个值,该值指示 Background
    Worker 是否支持异步取消。设置WorkerSupportsCancellation为true使得程序可 以调用CancelAsync方法提交终止挂起的后台操作的请求; 重要方法: 1、CancelAsync 请求取消挂起的后台操作 2、RunWorkerAsync 开始执行后台操作 3、ReportProgress 引发ProgressChanged事件 重要事件: 1、DoWork
    调用 RunWorkerAsync 时发生
    2、ProgressChanged 调用 ReportProgress 时发生 3、RunWorkerCompleted 当后台操作已完成、被取消或引发异常时发生 另外还有三个重要的参数是RunWorkerCompletedEventArgs以及DoWorkEvent
    Args、ProgressChangedEventArgs。 BackgroundWorker的各属性、方法、事件的调用机制和顺序:
    从上图可见在整个生活周期内发生了3次重要的参数传递过程: 参数传递1:此次的参数传递是将RunWorkerAsync(Object)中的Object传递到D
    oWork事件的DoWorkEventArgs.Argument,由于在这里只有一个参数可以传递, 所以在实际应用往封装一个类,将整个实例化的类作为RunWorkerAsync的Object 传递到DoWorkEventArgs.Argument; 参数传递2:此次是将程序运行进度传递给ProgressChanged事件,实际使用中 往往使用给方法和事件更新进度条或者日志信息; 参数传递3:在DoWork事件结束之前,将后台线程产生的结果数据赋给DoWor kEventArgs.Result一边在RunWorkerCompleted事件中调用RunWorkerComplete
    dEventArgs.Result属性取得后台线程产生的结果。 另外从上图可以看到DoWork事件是在后台线程中运行的,所以在该事件中不能 够操作用户界面的内容,如果需要更新用户界面,可以使用ProgressChanged事件 及RunWorkCompleted事件来实现。
    在WinForm中经常遇到一些费时的操作界面,比如统计某个磁盘分区的文件夹或 者文件数目,如果分区很大或者文件过多的话,处理不好就会造成“假死”的情况, 或者报“线程间操作无效”的异常,为了解决这个问题,可以使用委托来处理,在.n et2.0中还可以用BackgroundWorker类。
    BackgroundWorker类是.net 2.0里新增加的一个类,对于需要长时间操作而不需 要用户长时间等待的情况可以使用这个类。 注意确保在 DoWork 事件处理程序中不操作任何用户界面对象。而应该通过 Progr essChanged 和 RunWorkerCompleted 事件与用户界面进行通信。

    public partial class MainWindow : Window {
    private BackgroundWorker m_BackgroundWorker;// 申明后台对象
    public MainWindow() {
    		InitializeComponent(); m_BackgroundWorker = new BackgroundWorker(); // 实例化后台对象 
    		m_BackgroundWorker.WorkerReportsProgress = true; // 设置 可以通告进度 
    		m_BackgroundWorker.WorkerSupportsCancellation = true; // 设置可以取消 
    		m_BackgroundWorker.DoWork += new DoWorkEventHandler(DoWor k);
    		 m_BackgroundWorker.ProgressChanged += new ProgressChanged
    		EventHandler(UpdateProgress); 
    		m_BackgroundWorker.RunWorkerCompleted += new RunWorkerCom
    		pletedEventHandler(CompletedWork); 
    		m_BackgroundWorker.RunWorkerAsync(this);
    		void DoWork(object sender, DoWorkEventArgs e) {
    		BackgroundWorker bw = sender as BackgroundWorker;
    		 MainWindow win = e.Argument as MainWindow;
    			int i = 0; while ( i <= 100 ) {
    				if (bw.CancellationPending) {
    				e.Cancel = true; break;
    				}
    				 bw.ReportProgress(i++); 
    				 Thread.Sleep(1000);
    			}
    		} 
    		void UpdateProgress(object sender, ProgressChangedEventArgse) {
    			int progress = e.ProgressPercentage; 
    			label1.Content = string.Format("{0}",progress);
    		}
    		 void CompletedWork(object sender, RunWorkerCompletedEventArgs e) {
    				if ( e.Error != null) {
    				MessageBox.Show("Error");
    				} else if (e.Cancelled) {
    				MessageBox.Show("Canceled");
    				} else {
    				MessageBox.Show("Completed"); 
    				}
    		}
    	}
    	private void button1_Click(object sender, RoutedEventArgs e) {
    		m_BackgroundWorker.CancelAsync(); 
    	}
    }
    
    • 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

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 相关阅读:
    JAVA 实现《warcraft java版》游戏
    thinkphp 生成邀请推广二维码,保存到服务器并接口返回给前端
    mysql用户管理(sql语句)
    文字转音频软件哪个好用?这3款文字转换音频的软件识别率很高
    【计算机网络】广域网协议分析
    Rust插件连接失败
    LC844. 比较含退格的字符串
    Redis优化之单作品数据缓存
    定制开发肯德基自动化网站下单软件
    Windows独立安装程序此更新不适用于你的计算机怎么解决?
  • 原文地址:https://blog.csdn.net/u013400314/article/details/126661613