阅读目录
一:同步处理
二:异步处理
三:异步委托
四:通过委托同步调用方法
五:通过委托异步调用方法
一:同步处理
一个同步操作会阻塞整个当前的进程,直到这个操作完成才能执行下一段代码
二:异步处理
不会阻塞启动操作的调用线程,调用程序必须通过轮流检测,或者等待完成信号来发现调用的完成
三:异步委托
. 异步委托通过以异步方式调用同步方法的能力,在《同步调用WebService和异步调用WebService》一文中,里面也讲过了,同样一个Web服务,只是因为调用的方式不同,就成了同步调用和异步调用了,同步就是直接调用
. 当同步调用一个委托时,调用方法直接为当前线程的目标方法,这里就是指GetNameFirst()方法,如果编译器支持异步委托,则它将生成BeginInvoke()方法和EndInvoke()方法
. 只要是任何函数在我们的编译器中,除了直接调用之外,还有一个异步调用,也就是BeginInvoke()和EndInvoke(),BeginInvoke()返回结果是判断执行是否完成,EndInvoke()返回调用结果
四:通过委托同步调用方法
class User
{ //要调用的动态方法 public string GetNameFirst() {Thread.Sleep(30000);
return "从小就犯困"; }//要调用的静态方法
public static string GetNameSecond() {return "从小就犯困";
} }//委托声明(函数签名)
delegate string MyMethodDelegate(); static void Main(string[] args){
User user = new User();
//方式一:同步调用方法,声明一个委托变量mydelegate,且绑定到动态方法GetNameFirst MyMethodDelegate my_delegate = new MyMethodDelegate(user.GetNameFirst); string strResult = my_delegate(); Console.WriteLine(strResult); Console.ReadKey();}
因为我们让当前线程休眠的时间是30秒,所以我们要等到30秒后才能输出“从小就犯困”
五:通过委托异步调用方法
using System.Runtime.Remoting.Messaging;
delegate string MyMethodDelegate();
static void Main(string[] args){
//方式二:异步调用方法,声明一个委托变量mydelegate,且绑定到动态方法GetNameSecond
MyMethodDelegate my_delegate = new MyMethodDelegate(User.GetNameSecond); AsyncResult async_result;//此类封闭异步委托异步调用的结果,通过AsyncResult得到结果 //开始调用 async_result = (AsyncResult)my_delegate.BeginInvoke(null, null); //判断线程是否执行完成 while (!async_result.IsCompleted) { Console.WriteLine("正在异步执行方法GetNameSecond()......"); } Console.WriteLine("方法GetNameSecond()执行完成"); //等待委托调用的方法的完成 string strResult = my_delegate.EndInvoke(async_result); Console.WriteLine(strResult); Console.ReadKey();}