zoukankan      html  css  js  c++  java
  • 关于net2.0里面新出现的类backgroundworker的应用 (转)

    转自:http://www.cnblogs.com/dlwang2002/archive/2006/12/07/585093.html
        这是一个在
    .net2.0里面新出现的类,用于执行后台比较长的任务而又想能和UI有点操作的应用里面。

    普通情况下,你点击一个按钮,去后台执行一个process,如果你想得到结果,就得等这个process结束。通常,可以使用异步执行回调来解决这个问题。现在,backgroundworker给我们实现了这样一种简单的封装,可以把我们的复杂任务交给新的线程去处理,然后继续UI线程。等到我们的任务需要通知UI做什么事情的时候,可以report一下,在其事件里就可以直接使用UI控件,而不需要Control.Invoke去掉用之。

     

    有这样一个应用:客户需要把大量数据(需要执行3天)copy到另外一个机器,中间想能看到有多少数据被复制/失败等(实时报道)。

     

    在这个例子里面,我们的界面可能非常简单:一个开始按钮,一个结束按钮,一个richtextBox来显示运行记录。但是后台执行可能就会比较棘手。如果简单的执行,并且报告,那么整个界面将失去响应(都在同一个线程里面,造成忙碌)。这时候,可以使用这个backgroundworker了。它可以在后台执行,并且报告给界面实时信息,界面不会失去响应。

     

       先介绍一下backgroundworker的几个属性/方法

       .WorkerReportsProgress:是否可以向外报告进度。

       .WorkerSupportsCancellation :是否可以暂停任务

       . CancellationPending: 是否正在暂停中

       . RunWorkerAsync() : 开始执行任务。触发DoWork事件

       . ReportProgress(int percentPrgress,object userState) : 向外报告进度。触发ProgressChanged事件.其中,参数可以在ProgressChangedEventArgsworker_ProgressChanged(object sender, ProgressChangedEventArgs e))中得到

       . CancelAsync() :取消(暂停)执行。

       事件

        worker.DoWork += new DoWorkEventHandler(worker_DoWork);//执行任务

      worker.RunWorkerCompleted += new RunWorkerCompletedEventHandler(worker_RunWorkerCompleted);//任务结束时

        worker.ProgressChanged += new ProgressChangedEventHandler(worker_ProgressChanged)//报告状态

     

       按照上边的资料,我们这个应用就可以这样处理之

       formDisplay是用于显示实时状态的窗口。有DisplyMessage方法来显示信息到界面

       Hanlder类(处理文件copy的)里面:

           static void worker_ProgressChanged(object sender, ProgressChangedEventArgs e)

            {

                //show the message on windows

               formDisplay.DisplyMessage(copy, e.UserState.ToString());//show message.

            }

     

            static void worker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)

            {

                 string msg = "JOB copy : have been completed";

                 formDisplay.DisplyMessage(msg);//show message

            }

             

            static void worker_DoWork(object sender, DoWorkEventArgs e)

            {

                for()

                {

                     //copying

                    (sender as BackgroundWorker). ReportProgress(0,xxx complete);//report

    }

            }

    这样构造的程序里面,才不会出现UI失去响应。

     

    当然,通过写自己的异步处理也可以实现,功能更强大。只不过这个用起来更简单。

    至于backgroundworker是怎么实现的呢?这里有人已经做出了一些解答:

    http://blog.joycode.com/sunmast/archive/2006/03/02/about_system_componentmodel_asyncoperation.aspx

  • 相关阅读:
    业务领域建模Domain Modeling
    用例建模Use Case Modeling
    分析一套源代码的代码规范和风格并讨论如何改进优化代码
    结合工程实践选题调研分析同类软件产品
    如何提高程序员的键盘使用效率?
    第一次博客作业
    python_同时迭代多个对象
    python_判断奇偶数
    印象笔记markdown使用笔记
    【转】A*算法解决八数码问题
  • 原文地址:https://www.cnblogs.com/zxsoft/p/918804.html
Copyright © 2011-2022 走看看