线程间操作无效: 从不是创建控件“”的线程访问它。
听说2003里边不会,我不知道是不是这样的,反正一直都在用05~
05里会出这个问题的,貌似是为了安全~
哦,现在知道的解决方法有两个~
第一:
线程开始的时候加这么一句,OK,看不到错误了~
啥都能用了~
第二:
用委托,在05里,每个控件都有个 InvokeRequired的属性~
判断一下是不是true,是的话进行 Invoke操作的,完事了~
听说2003里边不会,我不知道是不是这样的,反正一直都在用05~
05里会出这个问题的,貌似是为了安全~
哦,现在知道的解决方法有两个~
第一:
Control.CheckForIllegalCrossThreadCalls
=
false
;
线程开始的时候加这么一句,OK,看不到错误了~
啥都能用了~
第二:
用委托,在05里,每个控件都有个 InvokeRequired的属性~
判断一下是不是true,是的话进行 Invoke操作的,完事了~
//
建立个委托
private delegate string returnStrDelegate();
// 搞个最简单滴取值滴方法 ~
private string returnSchool()
{
return CB_School.SelectedValue.ToString();
}
// 判断一下是不是该用Invoke滴 ~ ,不是就直接返回 ~
private string returnCB(returnStrDelegate myDelegate)
{
if (this.InvokeRequired)
{
return (string)this.Invoke(myDelegate);
}
else
{
return myDelegate();
}
}
// 别的线程里的调用哇 ~
string _school = returnCB(returnSchool);
private delegate string returnStrDelegate();
// 搞个最简单滴取值滴方法 ~
private string returnSchool()
{
return CB_School.SelectedValue.ToString();
}
// 判断一下是不是该用Invoke滴 ~ ,不是就直接返回 ~
private string returnCB(returnStrDelegate myDelegate)
{
if (this.InvokeRequired)
{
return (string)this.Invoke(myDelegate);
}
else
{
return myDelegate();
}
}
// 别的线程里的调用哇 ~
string _school = returnCB(returnSchool);
第一种方法只是简单的将错误提示禁用了,仍然存在跨线程调用控件的问题。为此可能造成两个线程同时或者循环改变该控件的状态导致线程死锁。
Invoke方法是同步的方法,所以执行过程是有先后顺序的,所以就不会出现那个异常了
来源:http://www.cnblogs.com/zyh-nhy/archive/2008/01/28/1056194.html