异步委托的简单用例

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”类型的已垃圾回收委托进行了回调。这可能会导致应用程序崩溃损坏和数据丢失。向非托管代码传递委托时,托管应用程序必须让这些委托保持活动状态,直到确信不会再次调用它们。 错误解决一例。(代码片段

委托泛型委托异步委托(新人,有问题请指出,有部分代码是拿其他博客主的)

异步委托

C# Winform 多线程异步委托进度条