艾伟_转载:C# 委托的同步调用和异步调用

  委托的Invoke方法用来进行同步调用。同步调用也可以叫阻塞调用,它将阻塞当前线程,然后执行调用,调用完毕后再继续向下进行。

  同步调用的例子:



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);    }}
时间: 2024-10-25 11:06:18

艾伟_转载:C# 委托的同步调用和异步调用的相关文章

艾伟_转载:把委托说透(2):深入理解委托

在上一篇随笔中我们通过示例逐步引入了委托,并比较了委托和接口.本文将重点剖析委托的实质. 委托在本质上仍然是一个类,我们用delegate关键字声明的所有委托都继承自System.MulticastDelegate.后者又是继承自System.Delegate类,System.Delegate类则继承自System.Object.委托既然是一个类,那么它就可以被定义在任何地方,即可以定义在类的内部,也可以定义在类的外部. 正如很多资料上所说的,委托是一种类型安全的函数回调机制, 它不仅能够调用实

艾伟_转载:一个.NET委托的故事:彼得,老板和宇宙

紧耦合 从前,在南方一块奇异的土地上,有个工人名叫彼得,他非常勤奋,对他的老板总是百依百顺.但是他的老板是个吝啬的人,从不信任别人,坚决要求随时知道彼得的工作进度,以防止他偷懒.但是彼得又不想让老板呆在他的办公室里站在背后盯着他,于是就对老板做出承诺:无论何时,只要我的工作取得了一点进展我都会及时让你知道.彼得通过周期性地使用"带类型的引用"(原文为:"typed reference" 也就是delegate??)"回调"他的老板来实现他的承诺,

艾伟_转载:.NET委托:一个C#睡前故事

英文版原作者:Chris Sells(www.sellsbrothers.com) 翻译:袁晓辉(www.farproc.com http://blog.csdn.net/uoyevoli) 原文地址: http://dev.csdn.net/article/82/82644.shtm 紧耦合 从前,在南方一块奇异的土地上,有个工人名叫彼得,他非常勤奋,对他的老板总是百依百顺.但是他的老板是个吝啬的人,从不信任别人,坚决要求随时知道彼得的工作进度,以防止他偷懒.但是彼得又不想让老板呆在他的办公室

C# 委托的同步调用和异步调用

委托的Invoke方法用来进行同步调用.同步调用也可以叫阻塞调用,它将阻塞当前线程,然后执行调用,调用完毕后再继续向下进行. 同步调用的例子: using System; using System.Threading; public delegate int AddHandler(int a, int b); public class Foo { static void Main() { Console.WriteLine("**********SyncInvokeTest***********

艾伟_转载:消息队列(Message Queue)简介及其使用

消息队列(Message Queue)简介及其使用 利用 MSMQ(Microsoft Message Queue),应用程序开发人员可以通过发送和接收消息方便地与应用程序进行快速可靠的通信.消息处理为您提供了有保障的消息传递和执行许多业务处理的可靠的防故障方法. MSMQ与XML Web Services和.Net Remoting一样,是一种分布式开发技术.但是在使用XML Web Services或.Net Remoting组件时,Client端需要和Server端实时交换信息,Serve

艾伟_转载:WinForm二三事(二)

监视消息循环 在上一篇文章中,我们讨论了消息循环是响应用户输入的根本,还提到了在WinForm中执行耗时操作是因为这个耗时操作与消息循环在同一个UI Thread上,导致不能处理用户的后续响应,造成程序假死.除此之外,还说到了Form中的WndProc方法,说这个方法就是Win32时代那个处理消息的方法的.Net版. 那么今天这篇文章我们就来编个小程序来模拟一下这个耗时操作,看看是不是如上一篇所说:耗时操作造成消息循环的临时中断不能响应用户后续输入. 程序很简单,就是一个简单的窗体,上面放置一个

使用委托实现同步回调与异步回调

使用委托可以执行的一项有用操作是实现回调.回调是传入函数的方法,在函数结束执行时调用该方法. 例如,有一个执行一系列数学操作的函数.在调用该函数时,也向其传递一个回调方法,从而在函数完成其计算工作时,调用回调方法,向用户通知计算结果.   同步回调    首先声明两个方法: AddTwoNumbers():接受两个整型实参以及一个类型委托 ResultCallback():接受一个字符串,并显示出来.代码如下: using System; using System.Collections.Gen

艾伟_转载:把委托说透(1):开始委托之旅 委托与接口

委托,本是一个非常基础的.NET概念,但前一阵子在园子里却引起轩然大波.先是Michael Tao的随笔让人们将委托的写法与茴香豆联系到了一起,接着老赵又用一系列文章分析委托写法的演变,并告诫"嘲笑孔乙己的朋友们,你们在一味鄙视"茴"的四种写法的同时,说不定也失去了一个了解中国传统文化的机会呢!". 在我个人看来,委托是.NET Framework中一个非常炫的特性,绝不会向有些评论里说的那样,根本没有机会接触.恰恰相反,我们几乎每天都会接触委托,使用委托. 其实园

艾伟_转载:解惑答疑:C#委托和事件

相信很多人一直为C#委托和事件所困惑,尤其是C#的初学者,学到这一部分会感觉比较困难,很有可能就放弃了,而且.NET对委托和事件封装得挺好,一般都不怎么用到自定义的委托和事件,所以放弃学习该技术就有了借口! 网上也有不少此类的文章,最具代表性的是张子阳的C#中的委托和事件这篇,写得的确很好,得到很多读者的赞赏,但我 看评论,还是发现了些问题,因为有不少读者是看了一遍又一遍,每次感觉都蛮好,可是隔一段时间,对"委托和事件"又迷糊了,于是又来看!我真搞不懂,为什 么会出现这种情况!后来想想