C#异步委托

在C#中,委托类型是一个类型安全的、面向对象的函数指针。当我们通过delegate关键字定义一个委托类型后,编译器会给委托类型生成三个方法:Invoke、BeginInvoke和EndInvoke。例如对于下面委托类型,可以通过ILSpy查看编译器生成的三个方法。private delegate int NumberAdd(int a, int b);同步执行委托...
摘要由CSDN通过智能技术生成

在C#中,委托类型是一个类型安全的、面向对象的函数指针。当我们通过delegate关键字定义一个委托类型后,编译器会给委托类型生成三个方法:Invoke、BeginInvoke和EndInvoke。

例如对于下面委托类型,可以通过ILSpy查看编译器生成的三个方法。

private delegate int NumberAdd(int a, int b);

同步执行委托实例

在使用委托的应用中,最常见的就是通过Invoke()方法以同步方式执行委托实例。也就是说,调用委托的线程将会一直等待,直到委托调用完成。

下面看一个同步执行委托的例子,在numberAdd委托实例中,通过Sleep(3000)模拟了一个耗时的操作:

NumberAdd numberAdd = (a, b) => {
    Thread.Sleep(3000);
    Console.WriteLine("----> NumberAdd() on thread is {0}", Thread.CurrentThread.ManagedThreadId);
    Console.WriteLine("----> start to calc {0} + {1}",a,b);
    Console.WriteLine("----> test result is {0}",a+b);
    return a + b;
};

Console.WriteLine("main thread (id: {0}) invoke numberAdd function", Thread.CurrentThread.ManagedThreadId);
//int result = numberAdd(2, 5);
int result = numberAdd.Invoke(2, 5);
Console.WriteLine("main thread (id: {0}) get the result: {1}", Thread.CurrentThread.ManagedThreadId, result);

代码的输出为下,从结果中可以看出,主线程执行委托实例过程中将会被阻塞,直到委托实例执行完成,主线程才会继续执行。

在很多应用中,一个方法可能要执行很久,例如加载一个很大的文档,或者执行一个耗时的数据库操作。如果我们使用同步的方式执行方法,那么主线程会一直阻塞,直到这个方法执行完成,表现就是应用程序没有相应,影响用户体验。这时,就可以考虑通过委托的异步性进行方法调用。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值