方法一:System.Windows.Forms.Control.CheckForIllegalCrossThreadCalls = false;
不推荐使用这种方式,禁止编译器对跨线程访问做检查的方式实现。
方法二:使用delegate和invoke
-
private delegate void UpdateLabel2Delegate(string message);
-
void UpdateLabel2(string message)
-
{
-
if (label1.InvokeRequired)
-
{
-
UpdateLabel2Delegate md = new UpdateLabel2Delegate(UpdateLabel2);
-
label1.Invoke(md, new object[] { message });
-
//label1.BeginInvoke(md, new object[] { message });
-
}
-
else
-
{
-
label1.Text = message;
-
}
-
}
或者:
-
void UpdateLabel2(string message)
-
{
-
this.Invoke((EventHandler)delegate{ this.label1.Text = message;});
-
}
或者:(不使用委托方式)
-
private void button2_Click(object sender, EventArgs e)
-
{
-
Thread thread1 = new Thread(new ParameterizedThreadStart(UpdateLabel2));
-
thread1.Start("更新Label");
-
}
-
private void UpdateLabel2(object str)
-
{
-
if (label2.InvokeRequired)
-
{
-
// 当一个控件的InvokeRequired属性值为真时,说明有一个创建它以外的线程想访问它
-
Action<string> actionDelegate = (x) => { this.label2.Text = x.ToString(); };
-
// 或者
-
// Action<string> actionDelegate = delegate(string txt) { this.label2.Text = txt; };
-
this.label2.Invoke(actionDelegate, str);
-
}
-
else
-
{
-
this.label2.Text = str.ToString();
-
}
-
}
方法三:使用BackgroundWorker组件
-
private void button4_Click(object sender, EventArgs e)
-
{
-
using (BackgroundWorker bw = new BackgroundWorker())
-
{
-
bw.RunWorkerCompleted += new RunWorkerCompletedEventHandler(bw_RunWorkerCompleted);
-
bw.DoWork += new DoWorkEventHandler(bw_DoWork);
-
bw.RunWorkerAsync("Tank");
-
}
-
}
-
void bw_DoWork(object sender, DoWorkEventArgs e)
-
{
-
// 这里是后台线程, 是在另一个线程上完成的, 这里是真正做事的工作线程
-
// 可以在这里做一些费时的,复杂的操作
-
Thread.Sleep(5000);
-
e.Result = e.Argument + "工作线程完成";
-
}
-
void bw_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
-
{
-
//这时后台线程已经完成,并返回了主线程,所以可以直接使用UI控件了
-
this.label4.Text = e.Result.ToString();
-
}
--------------------- 作者:believe209 来源:CSDN 原文:https://blog.csdn.net/wangzhen209/article/details/52412205?utm_source=copy 版权声明:本文为博主原创文章,转载请附上博文链接!