zoukankan      html  css  js  c++  java
  • BackgroundWorker

    BackgroundWorker:线程执行完毕之后我们可以继续一些操作

    示例:

     class Program
        {
            static void Main(string[] args)
            {
    
                Console.WriteLine("Main(string[] args)方法中:当前执行的线程编号:{0}", Thread.CurrentThread.ManagedThreadId);
    
                //BackgroundWorker
                //创建一个后台执行者对象
                BackgroundWorker backWorker = new BackgroundWorker();
                //设置该对象要在后台执行的方法
                backWorker.DoWork += new DoWorkEventHandler(backWorker_DoWork);
    
                //设置另外一个事件:当程序执行完毕后触发的事件
                backWorker.RunWorkerCompleted += new RunWorkerCompletedEventHandler(backWorker_RunWorkerCompleted);
    
                //开始执行
                backWorker.RunWorkerAsync(new int[] { 1, 100 });
                Console.WriteLine("主线程继续.......");
                Console.ReadKey();
            }
            //当后台方法执行完毕后触发的事件
            static void backWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
            {
                Console.WriteLine("backWorker_RunWorkerCompleted方法中:当前执行的线程编号:{0}", Thread.CurrentThread.ManagedThreadId);
                Console.WriteLine("最后输出结果是:{0}", e.Result);
            }
    
    
            //要在后台执行的方法
            static void backWorker_DoWork(object sender, DoWorkEventArgs e)
            {
                Console.WriteLine("backWorker_DoWork方法中:当前执行的线程编号:{0}", Thread.CurrentThread.ManagedThreadId);
                if (e.Argument != null)
                {
                    int[] arr = e.Argument as int[];
                    //把方法调用完毕后的值赋值给e.Result
                    e.Result = Sum(arr[0], arr[1]);
                }
    
            }
            static int Sum(int from, int to)
            {
                int sum = 0;
                for (int i = from; i <= to; i++)
                {
                    sum += i;
                }
                return sum;
            }
        }
    

      

  • 相关阅读:
    MongoDB存储时间
    如何在博客园随笔中增加章节导航
    如何优雅地从CSDN转载文章
    线段树详解(原理、实现与应用)
    Codeforces 1076D——最短路算法
    顶点支配、独立与覆盖
    CodeForces
    数据结构一——顺序表
    平面图的基本概念及性质
    编程之美——一摞烙饼的排序(暴搜+剪枝)
  • 原文地址:https://www.cnblogs.com/entclark/p/8025383.html
Copyright © 2011-2022 走看看