zoukankan      html  css  js  c++  java
  • C# 使用BackgroundWorker例子及注意点

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

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

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

    先引入命名空间:using System.Threading;  using System.Net;  

    整个Form1窗体代码如下:

    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 事件中与界面长须打交道,把生产的随机整数显示到窗体上。

    界面编译后运行如图:

  • 相关阅读:
    Chrome浏览器的下拉选择框option有黑框的问题
    修改input checkbox和radio默认样式
    VsCode安装cssrem插件实现px转rem
    js实现小球的弹性碰撞
    CSS 技巧 -- 不定宽溢出文本适配滚动
    记忆化递归和递推
    DOM事件中target和currentTarget的区别
    TypeScripy + Vue Property Decorator + Vue Router,组件内的导航守卫无效
    行内元素没有内容时设置默认的宽高
    焦点元素,添加半透明遮罩
  • 原文地址:https://www.cnblogs.com/netserver/p/5775027.html
Copyright © 2011-2022 走看看