C#中线程间操作无效: 从不是创建控件 txtBOX 的线程访问它
delegate void 委托名(方法名);
void 方法名()
{
if(txtBox.invokeRequered)
{
委托名 d=new 委托名();
txtBox.invoke(d);
}
else
{
具體的執(zhí)行語句
}
}
原來是存在跨線程調(diào)用控件的問題
解決方法有兩種:第一是加一句話,第二是用委托。因為一句話成功了?我就沒有用委托了~??
1.解決方法就加了一句話
private?void?mycomm_DataReceived(object?sender,?System.IO.Ports.SerialDataReceivedEventArgs?e)
????????{
????????????線程開始的時候加這么一句
????????????Control.CheckForIllegalCrossThreadCalls?=?false;
????????
????????????string?str?=?mycomm.ReadExisting().ToString();
????????????txtreceive.Text?=?txtreceive.Text?+?str;
????????}
ok?程序就運行成功了~
第二:
用委托,在05里,每個控件都有個InvokeRequired的屬性~
判斷一下是不是true,是的話進行Invoke操作的,完事了~
?
????????private?delegate?void?ShowDelegate(string?strshow);
????????public?void?Show(string?strshow)
????????{
????????????if?(this.txtreceive.InvokeRequired)
????????????{
?????????????//???this.txtreceive.BeginInvoke(new?ShowDelegate(Show),?strshow);//這個也可以
????????????????this.txtreceive.Invoke(new?ShowDelegate(Show),?strshow);
????????????}
????????????else
????????????{
????????????????????this.txtreceive.Text?+=?strshow;
????????????}
????????}
第一種方法只是簡單的將錯誤提示禁用了,仍然存在跨線程調(diào)用控件的問題。為此可能造成兩個線程同時或者循環(huán)改變該控件的狀態(tài)導(dǎo)致線程死鎖。?
Invoke方法是同步的方法,所以執(zhí)行過程是有先后順序的,所以就不會出現(xiàn)那個異常了?最好是用第二種方法
總結(jié)
以上是生活随笔為你收集整理的C#中线程间操作无效: 从不是创建控件 txtBOX 的线程访问它的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 软件开发中需要专职的 QA 吗?
- 下一篇: 编程复杂性等级划分