• C#异步调用的好处和方法


    我们要明确,为什么要进行异步回调?众所周知,普通方法运行,是单线程的,如果中途有大型操作(如:读取大文件,大批量操作数据库,网络传输等),都会导致方法阻塞,表现在界面上就是,程序卡或者死掉,界面元素不动了,不响应了。异步方法很好的解决了这些问题,异步执行某个方法,程序立即开辟一个新线程去运行你的方法,主线程包括界面就不会死掉了。异步如何开始,好理解,现在我们讨论的是如何结束这个异步出来的新线程。
    首先,异步出来的新线程,必须回收,不回收是浪费资源的可耻行为,.NET也是不允许的,所以你别想钻空子,俗话说,请神容易送神难,就是这个道理。下面你可以很容易想到,回收分为2种情况:主动回收和被动回收(当然,这是我自己的理解,微软可不是这么说的),主动回收就是,你去监视那个线程,并且等待,当异步方法完成了,就把异步线程回收,焦点回归主线程,实际上就是上篇文章《C#异步初步》的那种情况,BeginInvoke之后又EndInvoke,如果在EndInvoke的时候,该异步线程没有完成操作,那么整个程序,包括主线程,又在阻塞了,又会出现界面“死”的情况。要想解决这个问题,就使用“被动回收”方式,其中一个重要的办法就是“异步回调”。 核心有二: A、 用回调函数(本例中为CallBackMethod),异步结束后,自动调用此回调函数。 B、 而不在主线程中手工等待异步结束,如上两例中在主线程中调用EndInvoke。此种方法,是在回调函数中调用EndInvoke的。 异步回调的大概流程是这样的:首先启动异步,启动参数加上异步结束时执行的方法,然后这个异步线程就不用管了,最后当这个异步线程自己完成工作了,就自动执行启动参数里的那个方法,这样确实很省心,可是代码写起来,就很复杂了。 下面是搜藏的代码:

    1. //首先准备好,要进行异步的方法(能异步的,最好不多线程)
    2. privatestringMethodName(intNum,outintNum2)
    3. {
    4. Num2=Num;
    5. return"HelloWorld";
    6. }
    7. //程序终点
    8. //异步完成时,执行的方法(回调方法),此方法只能有IAsyncResult一个参数,但是该参数几乎万能,可以传递object
    9. privatevoidCallBackMethod(IAsyncResultar)
    10. {
    11. //从异步状态ar.AsyncState中,获取委托对象
    12. DelegateNamedn=(DelegateName)ar.AsyncState;
    13. //输出参数
    14. inti;
    15. //一定要EndInvoke,否则你的下场很惨
    16. stringr=dn.EndInvoke(outi,ar);
    17. MessageBox.Show("异步完成喽!i的值是"i.ToString()",r的值是"r);
    18. }
    19. //定义与方法同签名的委托
    20. privatedelegatestringDelegateName(intNum,outintNum2);
    21. //程序入口
    22. privatevoidRun()
    23. {
    24. //实例化委托并初赋值
    25. DelegateNamedn=newDelegateName(MethodName);
    26. //输出参数
    27. inti;
    28. //实例化回调方法
    29. //把AsyncCallback看成Delegate你就懂了,实际上AsyncCallback是一种特殊的Delegate,就像Event似的
    30. AsyncCallbackacb=newAsyncCallback(CallBackMethod);
    31. //异步开始
    32. //如果参数acb换成null则表示没有回调方法
    33. //最后一个参数dn的地方,可以换成任意对象,该对象可以被回调方法从参数中获取出来,写成null也可以。参数dn相当于该线程的ID,如果有多个异步线程,可以都是null,但是绝对不能一样,不能是同一个object,否则异常
    34. IAsyncResultiar=dn.BeginInvoke(1,outi,acb,dn);
    35. //去做别的事
    36. //…………
    37. }
    38. //最后的结果应该是:i=1,r="HelloWorld"
    39. //另外,如果可以,定义委托的时候可以选择不用过多的修饰:
    40. ///<summary>
    41. ///定义委托
    42. ///</summary>
    43. ///<returns></returns>
    44. publicdelegateboolAsyncdelegate();
    45. ///<summary>
    46. ///Callbackmethodmusthavethesamesignatureasthe
    47. ///AsyncCallbackdelegate
    48. ///</summary>
    49. ///<paramname="ar"></param>
    50. privatevoidCallbackMethod(IAsyncResultar)
    51. {
    52. //Retrievethedelegate.
    53. Asyncdelegatedlgt=(Asyncdelegate)ar.AsyncState;
    54. //CallEndInvoketoretrievetheresults.
    55. dlgt.EndInvoke(ar);
    56. }
    57. //其他方法中调用:
    58. //异步执行
    59. //指定委托方法
    60. Asyncdelegateisgt=newAsyncdelegate(icpInfo.Insert);
    61. IAsyncResultar=isgt.BeginInvoke(newAsyncCallback(CallbackMethod),isgt);

    转:http://www.cnblogs.com/xiaoli0414/archive/2007/11/27/974534.html

  • 相关阅读:
    实验17:NAT
    实验16:ACL
    实验15: STP
    实验14:VLAN间的路由
    实验13:VLAN/TRUNK/VTP/
    Linux软件管理--RPM工具
    Linux拓展练习部分--输入输出 / find部分 /基础拓展2
    linux文件管理--压缩打包
    find 文件查找
    防火墙知识点
  • 原文地址:https://www.cnblogs.com/xiurui12345/p/2424480.html
Copyright © 2020-2023  润新知