委托方式实现异步调用

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

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

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 @   丹心石  阅读(466)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示