winform2.0中解决跨线程操作控件的方法总结

winform2。0中默认是不允许直接跨线程访问控件的,否则会抛出异常,这个问题以前就遇到过,但是由于当时懒就绕过去了,今天实在是绕不过去了,下定决心把这个问题搞清楚,经过不懈的努力,终于搞定了,很高兴。总结如下:

 

方法一:关闭线程安全检查

Control.CheckForIllegalCrossThreadCalls = false;

将上述代码放在Form_load中即可

 

方法二:使用委托

#region 方法二 使用自定义委托 ///

/// 方法二使用自定义委托来完成对主线程控件的调用 /// /// private delegate void ListBoxCallBack(int i); private void button2_Click(object sender, EventArgs e) { Thread t = new Thread(new ThreadStart(TestWithDelegate)); t.Start(); } private void TestWithDelegate() { ListBoxCallBack obj = new ListBoxCallBack(DoAddValue); this.Invoke(obj, 5); //这里this很重要,是执行当前form的invoke方法 } private void DoAddValue(int i) { for (int j = 0; j < i; j++) { lvUpdateList.Items.Add(i.ToString()); } } #endregion

方法三:也是使用委托,

 

 #region 方法三 使用空间的InvokeRequired方法,本质也是借助委托实现
        ///


        ///
        ///

        ///
        ///
        private void button3_Click(object sender, EventArgs e)
        {
            Thread t = new Thread(new ThreadStart(SetResult));
            t.Start();
        }

        private void SetResult()
        {
            DoSetResult(5);
        }

        public delegate void SetTextHandler(int result); 
        private void DoSetResult(int result)
        {
            if (lvUpdateList.InvokeRequired)
            {
                SetTextHandler obj = new SetTextHandler(DoSetResult);
                lvUpdateList.Invoke(obj,5);
            }
            else
            {
                lvUpdateList.Items.Add(result.ToString());
            }
        }

 

 

但是与方法二不同,方法二是对调用当前form的Invoke的方法,这样的好处是可以跨线程操作form中的所有控件,方法三则是执行单个控件的invoke方法,因此跨线程的时候只能访问当前控件,访问其他控件依然会抛出异常。具体用哪一种,根据需要吧。

你可能感兴趣的:(c#)