异步委托的简单用例
Posted srckeeper
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了异步委托的简单用例相关的知识,希望对你有一定的参考价值。
1 //定义一个委托 2 static Func<int, int, string> delFunc = (a, b) => 3 { 4 Console.WriteLine("委托线程:" + Thread.CurrentThread.ManagedThreadId); 5 return (a + b).ToString(); 6 }; 7 8 static void Main(string[] args) 9 { 10 Console.WriteLine("主线程:"+Thread.CurrentThread.ManagedThreadId); 11 12 //同步调用委托 13 //string str = delFunc(3,4); 14 15 //异步调用委托(原理:用线程池中线程,执行委托指向的方法) 16 IAsyncResult ar = delFunc.BeginInvoke(3, 4, CallBackFn, "我是回调函数参数");//回调函数和回调函数参数 17 //string result = delFunc.EndInvoke(ar);//EndInvoke方法会阻塞,等待异步委托的结束 18 19 Console.ReadLine(); 20 } 21 22 //异步委托执行完成后,回调的函数 23 static void CallBackFn(IAsyncResult iar) 24 { 25 object obj = iar.AsyncState;//我是回调函数参数 26 27 AsyncResult ar = iar as AsyncResult; 28 Func<int, int, string> del = ar.AsyncDelegate as Func<int, int, string>; 29 string result = del.EndInvoke(ar);//异步委托的结果,在这里委托已经执行完毕,不会再阻塞。 30 31 Console.WriteLine("回调线程:" + Thread.CurrentThread.ManagedThreadId); 32 }
以上是关于异步委托的简单用例的主要内容,如果未能解决你的问题,请参考以下文章
对“xxx”类型的已垃圾回收委托进行了回调。这可能会导致应用程序崩溃损坏和数据丢失。向非托管代码传递委托时,托管应用程序必须让这些委托保持活动状态,直到确信不会再次调用它们。 错误解决一例。(代码片段