1.首先通过按键创建子线程:
创建子线程,子线程调用changeText方法。
private void btnOK_Click(object sender, EventArgs e)
{
Thread th = new Thread(changeText);
th.Name = "new Thread!";
th.IsBackground = true;
th.Start();
}
2.子线程操作弹窗提示:
void changeText()
{
Thread.Sleep();
MessageBox.Show("进入子线程:"+Thread.CurrentThread.Name);
}
效果图:
3.子线程修改主线程控件
(1)错误的直接使用:
void changeText()
{
Thread.Sleep();
textBox1.Text = "进入子线程!";
}
效果图:
(2)关闭跨线程的检查:
CheckForIllegalCrossThreadCalls = false;
效果图:
(3)对跨线程进行检查
声明委托:
注:参数类型是object型
public delegate void changeTextHandler(object str);
按键点击调用方法修改控件:
注:参数不是在线程创建的时候写入,是在start函数写入!
private void btnOK_Click(object sender, EventArgs e)
{
Thread th = new Thread(changeText);
th.Name = "new Thread!";
th.IsBackground = true;
th.Start("进入子线程!");
}
修改控件的方法(带一个参数):
void changeText(object str)
{
if (textBox1.InvokeRequired == true)
{
changeTextHandler ct = new changeTextHandler(changeText);
textBox1.Invoke(ct, new object[] { str });
}
else
{
textBox1.Text = str.ToString();
}
}
效果图:
(4)使用MethodInvoker解决跨线程问题
- MethodInvoker是无参无返回值;
- Action是多参无返回;
- Func是多参又返回。
private void btnOK_Click(object sender, EventArgs e)
{
Thread th = new Thread(changeText);
th.Name = "new Thread!";
th.IsBackground = true;
th.Start();
}
调用对事件的处理方法:
void changeText()
{
Thread.Sleep();
MethodInvoker ln = new MethodInvoker(change);
this.BeginInvoke(ln);
}
调用对控件的修改方法:
void change()
{
textBox1.Text = "进入子线程!";
}
效果图: