委托方式实现异步调用

异步是为了解决阻塞问题,同步是为了协调控制

异步调用的第一种实现方式即委托方式,步骤如下:

1.public delegate int MyDelegate(int x,int y);  //声明委托类型

2.MyDelegate md=new MyDelegate(Add); //定义并实例化委托对象,并为委托指定方法Add

3.public static int Add(int x,int y){ 

Thread.Sleep(5000);//模拟计算时间

return x+y;}  //定义与委托对应的方法Add,此处也可以使用Lamda表达式合并 2-3

4.IASyncResult iar=md.BeginInvoke(10,20,new AsyncCallback(

(ar)=>{

AsyncResult result=(AsyncResult)ar;    //把IAsyncResult接口参数 ar 的实例转换成 对应的AsyncResult类型对象

MyDelegate md=(MyDelegate)result.AsyncDelegate;  //该属性封装了调用它的委托

Console.WriteLine("10+20={0}",md.EndInvoke(ar));  //通过委托对象md调用其EndInvoke方法获取结果

Console.WriteLine(ar.AsyncState);

}

),"test")

实例分析:BeginInvoke(Params params,AsyncCallback asyncCallback,object asyncState)

params:委托方法的参数列表

asyncCallback:异步委托执行完毕后的回调方法

asyncState:封装于asyncCallback参数 IAsyncResult 的object类型的参数

委托的invoke()方法等同于delegate(),属于同步方法,会阻塞。

通过以上示例可知 BeginInvoke()的返回值实现了IAsyncResult接口,而EndInvoke()方法需要这个参数来处理获取结果 。

只要提供了AsyncCallback对象,当异步调用完成时便会自动调用AsnycCallback对象的方法,该方法有一个IAsyncCallback 类型的参数,这个参数是关键。

 

posted @ 2020-06-19 14:38  丹心石  阅读(472)  评论(0)    收藏  举报