C# 委托的同步调用和异步调用
2015-07-31 09:47
786 查看
委托的Invoke方法用来进行同步调用。同步调用也可以叫阻塞调用,它将阻塞当前线程,然后执行调用,调用完毕后再继续向下进行。
同步调用的例子:
运行结果:
同步调用会阻塞线程,如果是要调用一项繁重的工作(如大量IO操作),可能会让程序停顿很长时间,造成糟糕的用户体验,这时候异步调用就很有必要了。
异步调用不阻塞线程,而是把调用塞到线程池中,程序主线程或UI线程可以继续执行。
委托的异步调用通过BeginInvoke和EndInvoke来实现。
异步调用:
可以看到,主线程并没有等待,而是直接向下运行了。
但是问题依然存在,当主线程运行到EndInvoke时,如果这时调用没有结束(这种情况很可能出现),这时为了等待调用结果,线程依旧会被阻塞。
解决的办法是用回调函数,当调用结束时会自动调用回调函数
回调异步:
同步调用的例子:
using System; using System.Threading; public delegate int AddHandler(int a, int b); public class Foo { static void Main() { Console.WriteLine("**********SyncInvokeTest**************"); AddHandler handler = new AddHandler(Add); int result = handler.Invoke(1,2); Console.WriteLine("Do other work ... ... ..."); Console.WriteLine(result); Console.ReadLine(); } static int Add(int a, int b) { Console.WriteLine("Computing "+a+" + "+b+" ..."); Thread.Sleep(3000); Console.WriteLine("Computing Complete."); return a+b; } }
运行结果:
**********SyncInvokeTest************** Computing 1 + 2 ... Computing Complete. Do other work... ... ... 3
同步调用会阻塞线程,如果是要调用一项繁重的工作(如大量IO操作),可能会让程序停顿很长时间,造成糟糕的用户体验,这时候异步调用就很有必要了。
异步调用不阻塞线程,而是把调用塞到线程池中,程序主线程或UI线程可以继续执行。
委托的异步调用通过BeginInvoke和EndInvoke来实现。
异步调用:
using System; using System.Threading; public delegate int AddHandler(int a, int b); public class Foo { static void Main() { Console.WriteLine("**********AsyncInvokeTest**************"); AddHandler handler = new AddHandler(Add); IAsyncResult result = handler.BeginInvoke(1,2,null,null); Console.WriteLine("Do other work... ... ..."); Console.WriteLine(handler.EndInvoke(result)); Console.ReadLine(); } static int Add(int a, int b) { Console.WriteLine("Computing "+a+" + "+b+" ..."); Thread.Sleep(3000); Console.WriteLine("Computing Complete."); return a+b; } }
运行结果:
**********AsyncInvokeTest************** Do other work... ... ... Computing 1 + 2 ... Computing Complete. 3
可以看到,主线程并没有等待,而是直接向下运行了。
但是问题依然存在,当主线程运行到EndInvoke时,如果这时调用没有结束(这种情况很可能出现),这时为了等待调用结果,线程依旧会被阻塞。
解决的办法是用回调函数,当调用结束时会自动调用回调函数
回调异步:
public class Foo { static void Main() { Console.WriteLine("**********AsyncInvokeTest**************"); AddHandler handler = new AddHandler(Add); IAsyncResult result = handler.BeginInvoke(1,2,new AsyncCallback(AddComplete), "AsycState:OK"); Console.WriteLine("Do other work ... ... ..."); Console.ReadLine(); } static int Add(int a, int b) { Console.WriteLine("Computing "+a+" + "+b+" ..."); Thread.Sleep(3000); Console.WriteLine("Computing Complete."); return a+b; } static void AddComplete(IAsyncResult result) { AddHandler handler = (AddHandler)((AsyncResult)result).AsyncDelegate; Console.WriteLine(handler.EndInvoke(result)); Console.WriteLine(result.AsyncState); } }
相关文章推荐
- c#调用COM组件
- C#实现把指定数据写入串口
- C#中抽象方法与虚拟方法的区别
- c#中虚函数的相关使用方法
- C#实现多线程的同步方法实例分析
- C#中尾递归的使用、优化及编译器优化
- C#通用邮件发送类分享
- C#中this的用法集锦
- C#.NET获取拨号连接的宽带连接方法
- C#实现AddRange为数组添加多个元素的方法
- C#中Equality和Identity浅析
- C#生成饼形图及添加文字说明实例代码
- C#判等对象是否相等的方法汇总
- C#简单的向量用法实例教程
- C#实现基于链表的内存记事本实例
- C#托管堆对象实例包含内容分析
- C#实现按照指定长度在数字前补0方法小结
- C# 通过 inline-asm 解决嵌入x86汇编
- C#虚方法的声明和使用实例教程
- C#获取文件夹及文件的大小与占用空间的方法