C# Invoke
来源:互联网 发布:父与子的编程之旅 pdf 编辑:程序博客网 时间:2024/06/06 14:15
要在程序中实现在一个线程中添加tabPage的问题,但是tabControl实在主进程中建立的,所以在运行时报错:线程间操作无效: 从不是创建控件“tabControl1”的线程访问它。
然后在网上查,需要用Invoke,delegate。网上有很多关于这些的资料,有些写的挺好的,看了感觉挺明白。
下面这段是网上的:
Invoke或者BeginInvoke方法都需要一个委托对象作为参数。委托类似于回调函数的地址,因此调用者通过这两个方法就可以把需要调用的函数地址封送给界面线程。这些方法里面如果包含了更改控件状态的代码,那么由于最终执行这个方法的是界面线程,从而避免了竞争条件,避免了不可预料的问题。如果其它线程直接操作界面线程所属的控件,那么将会产生竞争条件,造成不可预料的结果。
使用Invoke完成一个委托方法的封送,就类似于使用SendMessage方法来给界面线程发送消息,是一个同步方法。也就是说在Invoke封送的方法被执行完毕前,Invoke方法不会返回,从而调用者线程将被阻塞。
使用BeginInvoke方法封送一个委托方法,类似于使用PostMessage进行通信,这是一个异步方法。也就是该方法封送完毕后马上返回,不会等待委托方法的执行结束,调用者线程将不会被阻塞。但是调用者也可以使用EndInvoke方法或者其它类似WaitHandle机制等待异步操作的完成。
但是在内部实现上,Invoke和BeginInvoke都是用了PostMessage方法,从而避免了SendMessage带来的问题。而Invoke方法的同步阻塞是靠WaitHandle机制来完成的。
我一开始是直接在线程里添加tabpage,下面这样,然后就报错
TabPage tp = new TabPage(); tp.Name = str.Substring(2); tp.Text = str_in.Substring(1); ListView lv = new ListView(); lv.Dock = System.Windows.Forms.DockStyle.Fill; this.tabControl1.Controls.Add(tp); tp.Controls.Add(lv)
后来用invoke
在线程中就这两句,将上面的操作卸载了addPage函数里,当然在一开始要声明public delegate void MyInvoke();
MyInvoke mi = new MyInvoke(addPage); this.BeginInvoke(mi);
private void addPage() { TabPage tp = new TabPage(); tp.Name = str.Substring(2); tp.Text = str_in.Substring(1); //ListView lv = new ListView(); //lv.Dock = System.Windows.Forms.DockStyle.Fill; this.tabControl1.Controls.Add(tp); //tp.Controls.Add(lv); }
- C# Invoke
- C# Invoke
- C# P/Invoke
- C#之P/Invoke
- C#中的Invoke
- C#中的Invoke
- c# invoke与beginInvoke
- C#之P/Invoke
- C# wpf Dispatch invoke
- c# Invoke和BeginInvoke
- C#中的Invoke
- C#中的Invoke
- C#中的Invoke
- C#中的Invoke
- C# Kinect Invoke()
- 【转】C#中的Invoke
- C#中的Invoke
- C#中的Invoke
- 程序员必读书籍及导读指南
- android 从matrix获取处理过的图片的实际宽度
- linux grep-管道命令
- mybatis-interceptor:Spring动态拦截器
- MongoDB基本管理命令
- C# Invoke
- 转载 C++ 的“反射”技术
- Android 5.1 编译
- SAT考试之SAT词汇记忆4步走
- kpush部署过程中遇到的问题
- iOS 二维码最简单的Zbar集成
- 判断一个物体播放没播放“Play”动画
- java反编译
- Mongodb数据分片的维护(新增分片到已有的分片复制集)