委托的异步

2018-06-17 19:46:13来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

1.委托的异步使用BeginInvoke,这样程序执行时不需要等待委托的函数执行完以后再执行下一句。

但是委托的异步如果有返回值

 

1
2
3
4
5
private delegate void invokeDelegate();
del = new invokeDelegate(StartMethod);
var re=   del.BeginInvoke(null, null);
MessageBox.Show( del.EndInvoke(re));
 MessageBox.Show("f");

这个时候就会堵塞,等待StartMethod执行完才会走到第5句,没有体现出异步的功能。

回调函数可以解决这个问题,可以将EndInvoke放在IAsyncCallback中执行,将3,4句改为

1
IAsyncResult ir = id.BeginInvoke(AddComplete, null);

 并添加以下函数:

 

1
2
3
4
5
prvite void AddComplete(IAsyncResult result)
{
      invokeDelegate handler = (invokeDelegate)((AsyncResult)result).AsyncDelegate;
      MessageBox.Show( handler.EndInvoke(result));
 }

 

这样就函数便不用等待委托执行完,可以先执行第5句。

StartMethod方法如下:

 

1
2
3
4
5
private void StartMethod()
{
     Thread.Sleep(5000);
    MessageBox.Show("c");
 }

委托的BeginInvoke实际上是放在threadpool中的。

2.control的invoke和BeginInvoke都是在主线程上的所以它们都会阻塞主线程(control所在线程)。beginInvoke不会阻塞支线程,所以它只能作为支线程的异步

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:利用扩展方法重写JSON序列化和反序列化

下一篇:asp.net架构基础知识--页面以及全局事件