• (转)C# 使用BackgroundWorker


    本文转载自:http://blog.csdn.net/andrew_wx/article/details/6615077

    该例子为使用BackgroundWorker在TextBox文本中产生一个10000以内并且能被5整除的数(1秒产生一个)

    操作界面可以启动线程,也可以停止线程,界面设计如图:

    先贴代码,有注释的地方就不解释了。

    整个Form1窗体代码如下

    引入命名空间:

    using System.Threading;  
    using System.Net;  

    完整代码:

    namespace BackgroundWorkerExample  
    {  
        public partial class Form1 : Form  
        {  
            public Form1()  
            {  
                InitializeComponent();  
                backgroundWorker1.WorkerReportsProgress = true;  
                backgroundWorker1.WorkerSupportsCancellation = true;  
                btn_Stop.Enabled = false;  
            }  
      
            private void btn_Start_Click(object sender, EventArgs e)  
            {  
                txt_Text.Text = "开始产生10000以内的随机数……
    
    ";  
                btn_Start.Enabled = false;  
                btn_Stop.Enabled = true;  
                //在后台线程开始操作  
                backgroundWorker1.RunWorkerAsync();  
            }  
      
            private void btn_Stop_Click(object sender, EventArgs e)  
            {  
                backgroundWorker1.CancelAsync();  
                btn_Stop.Enabled = false;  
                btn_Start.Enabled = true;  
            }  
      
            private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)  
            {  
                //不要直接使用组件实例名称(backgroundWorker1),因为有多个BackgroundWorker时,  
                //直接使用会产生耦合问题,应该通过下面的转换使用它  
                BackgroundWorker worker = sender as BackgroundWorker;  
                //下面的内容相当于线程要处理的内容。//注意:不要在此事件中和界面控件打交道  
                Random r = new Random();  
                int numCount = 0;  
                while (worker.CancellationPending == false)  
                {  
                    int num = r.Next(0, 10000);  
                    if (num % 5 == 0)  
                    {  
                        numCount++;  
                        worker.ReportProgress(0, num);  
                        Thread.Sleep(1000);  
                    }  
                }  
                e.Result = numCount;  
            }  
      
            private void backgroundWorker1_ProgressChanged(object sender, ProgressChangedEventArgs e)  
            {  
                int num = (int)e.UserState;  
                txt_Text.Text += num + " ";  
            }  
      
            private void backgroundWorker1_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)  
            {  
                if (e.Error == null)  
                    txt_Text.Text += "
    
    操作停止,共生产" + e.Result + "个能被5整除的随机数";  
                else  
                    txt_Text.Text += "
    操作过程中产生错误:" + e.Error;  
      
            }  
        }  
    }  

    该例子在 Backgroundworker 组件的辅助线程上随机产生整数,辅助线程运行DoWork事件处理程序,当产生能被5整除的整数时,使用ProgressChanged事件把整数显示到窗体上。程序执行到 RunWorkerAsync 方法时,将启动后台线程。 在Dowork事件中,如果应用程序没有取消后台操作,将不停的产生随机整数,然后判断该整数能否被5整除,如果能被5整除,执行work.ReportProgress方法来触发 ProgressChanged 事件,在 ProgressChanged 事件中与界面长须打交道,把生产的随机整数显示到窗体上。

    界面编译后运行如图:

  • 相关阅读:
    c++ --> #define中的三个特殊符号:#,##,#@
    网络通信 --> ZMQ安装和使用
    利用 mount 指令解决 Read-only file system的问题
    sed学习总结
    Verilog中锁存器与多路选择器
    Debian耳机声音问题
    MM32/STM32中断和事件梳理
    MM32 备份域学习(兼容STM32)
    有限状态机FSM(自动售报机Verilog实现)
    MM32 RTC学习(兼容STM32)
  • 原文地址:https://www.cnblogs.com/wpcnblog/p/5259936.html
Copyright © 2020-2023  润新知