不迎不送,来去自便,无茶无酒,谈笑随缘

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

     VS2005中,界面线程中的控件如果由其他线程进行更新时,编译器会自动抛出异常来避免这种不安全的跨线程访问方式。解决这个问题的一种方法是在界面线程中编写控件内容更新程序,并声明委托,利用Invoke方法进行实现。具体实现方法如下。

     假设我们的From1中有一个TextBox空间,名为txtBox,From1在Load的时候启动一个线程thread,线程处理函数为threadProc,在该线程中将Hello the world写入txtBox控件中。

     对于上面的问题,在以往VS2003中我们只需在thread线程的处理函数中加入this.txtBox.Text="Hello the world!"即可,而在VS2005中同样的写法编译器会抛出异常。在VS2005中正确的调用方法是先声明用于更新空间的委托,在定义一个更新控件用的方法,然后在线程函数中通过From1的InvokeRequired方法判断是否需要采用Invoke方式,如果需要使用Invoke方式访问,否则采用VS2003中的方式更新控件内容,代码如下:

//声明更新控件用的代理委托
protected delegate void UpdateControlText(string strText);
//定义更新控件的方法
protected void updateControlText(string strText)
{
      txtBox.Text = strText;
      return;
}
需要说明的是,上述委托和方法为From1对应类对象的成员,委托的参数必须与方法的参数完全相同。
在线程中需要更新控件的位置中添加如下代码:
           if (this.InvokeRequired)
            {
                UpdateControlText update = new UpdateControlText(updateControlText);
                this.Invoke(update, "Hello the world!");
            }
            else
            {
                this.txtBox.Text="Hello the world!";
            }

Invoke方法中第一个参数为委托类型的对象,构造该对象的时候采用updateControlText作为构造参数。从第二个参数开始为一个params object [] objParams的队列,可以容纳任意多任意类型的参数,但是针对每次调用来说必须要指定类型个数与UpdateControlText完全相同的参数表。虽然参数不同时编译器不会报错,但是会在运行中弹出异常

posted on 2007-09-03 22:36  wude  阅读(188)  评论(0编辑  收藏  举报