zoukankan      html  css  js  c++  java
  • 跨线程更新控件UI 武胜

    private void btnCalculate_Click(object sender, EventArgs e)
            {
                Thread mythread = new Thread(Calculate);
                mythread.IsBackground = true;        //設置為後臺線程,程式關閉后進程也關閉,如果不設置true,則程式關閉,此線程還在內存,不會關閉
                mythread.Start();
            }
            private void Calculate()
            {
                this.Invoke(new Action(() => { progressBarWay.Visible = true; }));
                Stopwatch stopwatch = Stopwatch.StartNew();
                this.Invoke(new Action(() => { progressBarWay.Maximum = 500; }));
                for (int i = 0; i < 500; i++)
                {
                    Thread.Sleep(5);
                    this.Invoke(new Action(() => { progressBarWay.Value = i; }));
                }
                this.Invoke(new Action(() => { progressBarWay.Visible = false; }));
                stopwatch.Stop();
                long lSearchTime = stopwatch.ElapsedMilliseconds;
                MessageBox.Show(lSearchTime.ToString() + "毫秒");
            }

    http://www.codeproject.com/Articles/269787/Accessing-Windows-Forms-Controls-across-Threads

    delegate void ChangeMyTextDelegate(Control ctrl, string text);

    This defines a reference to a method with a return type of "void" and takes two parameters: Control and String. Take a look at the following method that tries to update the text of a specified control.

    public static void ChangeMyText(Control ctrl, string text);
    {
        ctrl.Text = text;
    }

    This is all well and good, assuming that the thread that calls this method is the same thread that created the control. If not, we risk having our cars crash into one another.

    To counter this, we use the Control's "InvokeRequired" property and the delegate we defined a moment ago. The resulting code looks like this:

    delegate void ChangeMyTextDelegate(Control ctrl, string text);
    public static void ChangeMyText(Control ctrl, string text)
    {
        if (ctrl.InvokeRequired)
        {
            ChangeMyTextDelegate del = new ChangeMyTextDelegate(ChangeMyText);
            ctrl.Invoke(del, ctrl, text)
        }
        else
        {
            ctrl.Text = text;
        }
    }
  • 相关阅读:
    C# 排序技术研究与对比
    基于.net的通用内存缓存模型组件
    Scala学习笔记:重要语法特性
    一个初学者的指南,使用D3做数据绑定
    CLR垃圾回收的设计
    CLR线程概览(下)
    CLR线程概览(一)
    使用sos查看.NET对象内存布局
    .NET对象的内存布局
    MYC编译器源码之代码生成
  • 原文地址:https://www.cnblogs.com/zeroone/p/3048424.html
Copyright © 2011-2022 走看看