首页 > 代码库 > 委托的异步
委托的异步
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不会阻塞支线程,所以它只能作为支线程的异步
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。