public partial class Form1 : Form
{
private delegate void FlushClIEnt();//代理
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
Thread thread = new Thread(CrossThreadFlush);
thread.IsBackground=true;
thread.Start();
}
private void CrossThreadFlush()
{
//將代理綁定到方法
FlushClient fc = new FlushClIEnt(ThreadFuntion);
this.BeginInvoke(fc);//調用代理
}
private void ThreadFuntion()
{
while (true)
{
this.textBox1.Text = DateTime.Now.ToString();
Thread.Sleep(1000);
}
}
}
使用這種方式我們可以看到跨線程訪問的異常沒有了。但是新問題出現了,界面沒有響應了。為什麼 會出現這個問題,我們只是讓新開的線程無限循環刷新,理論上應該不會對主線程產生影響的。其實不然 ,這種方式其實相當於把這個新開的線程“注入”到了主控制線程中,它取得了主線程的控制。只要這個 線程不返回,那麼主線程將永遠都無法響應。就算新開的線程中不使用無限循環,使可以返回了。這種方 式的使用多線程也失去了它本來的意義。