C#(同步调用、异步调用、异步回调)

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. using System.Threading;  
  6. using System.Runtime.Remoting.Messaging;  
  7.   
  8. namespace ConsoleApplication1  
  9. {  
  10.     public delegate int AddHandler(int a, int b);  
  11.     public class AddMethod  
  12.     {  
  13.         public static int Add(int a, int b)  
  14.         {  
  15.             Console.WriteLine("开始计算:" + a + "+" + b);  
  16.             Thread.Sleep(3000); //模拟该方法运行三秒  
  17.             Console.WriteLine("计算完成!");  
  18.             return a + b;  
  19.         }  
  20.     }  
  21.       
  22.           
  23.     //**************同步调用***********  
  24.     //委托的Invoke方法用来进行同步调用。同步调用也可以叫阻塞调用,它将阻塞当前线程,然后执行调用,调用完毕后再继续向下进行。  
  25.   
  26.     //**************异步调用***********  
  27.     //异步调用不阻塞线程,而是把调用塞到线程池中,程序主线程或UI线程可以继续执行。  
  28.     //委托的异步调用通过BeginInvoke和EndInvoke来实现。  
  29.   
  30.     //**************异步回调***********  
  31.     //用回调函数,当调用结束时会自动调用回调函数,解决了为等待调用结果,而让线程依旧被阻塞的局面。  
  32.   
  33.     //注意: BeginInvoke和EndInvoke必须成对调用.即使不需要返回值,但EndInvoke还是必须调用,否则可能会造成内存泄漏。  
  34.     class Program  
  35.     {  
  36.         static void Main(string[] args)  
  37.         {  
  38.             Console.WriteLine("===== 同步调用 SyncInvokeTest =====");  
  39.             AddHandler handler = new AddHandler(AddMethod.Add);  
  40.             int result=handler.Invoke(1,2);  
  41.             Console.WriteLine("继续做别的事情。。。");  
  42.   
  43.             Console.WriteLine(result);  
  44.             Console.ReadKey();  
  45.   
  46.   
  47.             Console.WriteLine("===== 异步调用 AsyncInvokeTest =====");  
  48.             AddHandler handler1 = new AddHandler(AddMethod.Add);  
  49.             IAsyncResult result1=handler1.BeginInvoke(1,2,null,null);  
  50.             Console.WriteLine("继续做别的事情。。。");  
  51.   
  52.             //异步操作返回  
  53.             Console.WriteLine(handler1.EndInvoke(result1));  
  54.             Console.ReadKey();  
  55.   
  56.             Console.WriteLine("===== 异步回调 AsyncInvokeTest =====");  
  57.             AddHandler handler2 = new AddHandler(AddMethod.Add);  
  58.             IAsyncResult result2 = handler2.BeginInvoke(1, 2, new AsyncCallback(Callback), null);  
  59.             Console.WriteLine("继续做别的事情。。。");  
  60.             Console.ReadKey();  
  61.   
  62.   
  63.             //异步委托,也可以参考如下写法:  
  64.             //Action<object> action=(obj)=>method(obj);  
  65.             //action.BeginInvoke(obj,ar=>action.EndInvoke(ar),null);  
  66.             //简简单单两句话就可以完成一部操作。  
  67.         }  
  68.         static void Callback(IAsyncResult result)  
  69.         {  
  70.             AddHandler handler = (AddHandler)((AsyncResult)result).AsyncDelegate;  
  71.             Console.WriteLine(handler.EndInvoke(result));  
  72.         }  
  73.     }  
  74. }  
  75. 来源:http://blog.csdn.net/wanlong360599336/article/details/8781477
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. using System.Threading;  
  6. using System.Runtime.Remoting.Messaging;  
  7.   
  8. namespace ConsoleApplication1  
  9. {  
  10.     public delegate int AddHandler(int a, int b);  
  11.     public class AddMethod  
  12.     {  
  13.         public static int Add(int a, int b)  
  14.         {  
  15.             Console.WriteLine("开始计算:" + a + "+" + b);  
  16.             Thread.Sleep(3000); //模拟该方法运行三秒  
  17.             Console.WriteLine("计算完成!");  
  18.             return a + b;  
  19.         }  
  20.     }  
  21.       
  22.           
  23.     //**************同步调用***********  
  24.     //委托的Invoke方法用来进行同步调用。同步调用也可以叫阻塞调用,它将阻塞当前线程,然后执行调用,调用完毕后再继续向下进行。  
  25.   
  26.     //**************异步调用***********  
  27.     //异步调用不阻塞线程,而是把调用塞到线程池中,程序主线程或UI线程可以继续执行。  
  28.     //委托的异步调用通过BeginInvoke和EndInvoke来实现。  
  29.   
  30.     //**************异步回调***********  
  31.     //用回调函数,当调用结束时会自动调用回调函数,解决了为等待调用结果,而让线程依旧被阻塞的局面。  
  32.   
  33.     //注意: BeginInvoke和EndInvoke必须成对调用.即使不需要返回值,但EndInvoke还是必须调用,否则可能会造成内存泄漏。  
  34.     class Program  
  35.     {  
  36.         static void Main(string[] args)  
  37.         {  
  38.             Console.WriteLine("===== 同步调用 SyncInvokeTest =====");  
  39.             AddHandler handler = new AddHandler(AddMethod.Add);  
  40.             int result=handler.Invoke(1,2);  
  41.             Console.WriteLine("继续做别的事情。。。");  
  42.   
  43.             Console.WriteLine(result);  
  44.             Console.ReadKey();  
  45.   
  46.   
  47.             Console.WriteLine("===== 异步调用 AsyncInvokeTest =====");  
  48.             AddHandler handler1 = new AddHandler(AddMethod.Add);  
  49.             IAsyncResult result1=handler1.BeginInvoke(1,2,null,null);  
  50.             Console.WriteLine("继续做别的事情。。。");  
  51.   
  52.             //异步操作返回  
  53.             Console.WriteLine(handler1.EndInvoke(result1));  
  54.             Console.ReadKey();  
  55.   
  56.             Console.WriteLine("===== 异步回调 AsyncInvokeTest =====");  
  57.             AddHandler handler2 = new AddHandler(AddMethod.Add);  
  58.             IAsyncResult result2 = handler2.BeginInvoke(1, 2, new AsyncCallback(Callback), null);  
  59.             Console.WriteLine("继续做别的事情。。。");  
  60.             Console.ReadKey();  
  61.   
  62.   
  63.             //异步委托,也可以参考如下写法:  
  64.             //Action<object> action=(obj)=>method(obj);  
  65.             //action.BeginInvoke(obj,ar=>action.EndInvoke(ar),null);  
  66.             //简简单单两句话就可以完成一部操作。  
  67.         }  
  68.         static void Callback(IAsyncResult result)  
  69.         {  
  70.             AddHandler handler = (AddHandler)((AsyncResult)result).AsyncDelegate;  
  71.             Console.WriteLine(handler.EndInvoke(result));  
  72.         }  
  73.     }  
  74. }  
posted @ 2017-06-06 16:18  我叫阿良❤善良的良  阅读(235)  评论(0)    收藏  举报