NET并行计算技术基础.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
NET并行计算技术基础

.NET4.0并行计算技术基础(10)今天贴出TPL的最后一部分内容,后面的小节将转去介绍PLINQ。??????????????????????????????????????????? 金旭亮???????????????????????????????????? ? 2009.10.17============================================?19.3.9 处理并行计算中的异常在这一小节中,我们来探讨一下如何并行计算中的异常捕获与处理问题。1 处理并行循环中的异常在一个顺序执行的循环中,如果发生了一个异常,那么.NET的异常处理机制将会中止这个循环:?for(int i=0;i1000000;i++){//串行代码:如果在此处发生异常,将导致循环的提前中止。}?并行程序通常使用数据分区的手段,让多个线程并行执行同一个大循环的不同部分(比如将上述大循环份为4部分,用4个线程并行执行),这样一来,情况就变得复杂了。想象一下,假设在执行并行循环过程中,其中的一个线程发生了异常而终止,那么从理论上说,这意味着整个“大循环”已没有必要执行,因为继续执行下去有可能得到错误的结果。因此,必须让并行程序具备这样的一个机制:一个线程中发生的异常,应该能“传播”给其他正在工作的线程。.NET 并行计算开发小组的工程师们在设计并行任务库时,采用了以下的设计方案:如果正在执行并行循环中某个“子循环”的线程发生了异常,它会阻止执行自己执行后继的循环代码(直接使用.NET标准的异常处理机制即可),然后这一情况通知任务并行库,任务并行库在得到通知以后,不会再创建新的线程执行并行循环的其他“子循环”,并负责将“有一个线程已经停止执行”这一事件通报给正在执行的其他线程。其他线程在接到此“情况通报”后,可以根据实际情况决定是“立即退出”,还是先完成一些清理工作再退出,具体时机是由软件工程师定的,他可以在设计并行循环的任务函数时,编写专门的代码来处理这一问题。当所有执行并行循环代码的线程停止之后,任务并行库收集所有相关线程所抛出的异常,合并成为一个AggregateException异常抛出。可以在启动此并行循环操作的“主线程[1]”中捕获此异常,从而得知工作没有能顺利执行完毕。对于那些由可能执行很长时间的子循环,为了避免因长时间等待其终止, Parallel.For和Parallel.ForEach都提供了特定的重载形式,用到了一个ParallelLoopState参数,例如:?public static ParallelLoopResult For(int fromInclusive, int toExclusive, Actionint, ParallelLoopState body);?ParallelLoopState对象有一个IsExceptional属性,可以用于判断是否外部引发了一个异常,当其值为true时,表明属于同一并行循环的其他线程因为出现了未捕获的异常而终止,IsExceptional属性由任务并行库负责设置。这就是任务并行库在不同线程间完成“情况通报”的基本方式。示例程序HandleParallelLoopException展示了如何处理并行循环中的异常(图1920)。请读者自行阅读源码。

文档评论(0)

kabudou + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档