并行区域编程.PDFVIP

  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文档。上传文档
查看更多
并行区域编程

5.2.2 行区域编程 上面我们曾经说过循环并行化实际上是 行区域编程的一个特例,在这一小节我们将详细讨 论非循环的 行区域编程。并行区域简单的说就是通过循环并行化编译制导语句使得一段代 码能够在多个线程内部同时执行。本章的第一个例子就是一个 行区域的例子,根据环境变 量的设置,该程序在相应的线程内部打印出信息。 行区域编译制导语句的格式与使用限制 在C/C++语言中, 行区域编写的格式如下所示: #pragma omp parallel [clause[clause]…] block 其中block 是需 在多个线程中执行的代码块,每一个线程在遇到 行区域的编译制导语句 的时候,都会同时执行跟随其后的程序代码块。在并行区域的编译制导语句后面也可以跟随 一些子句,包括private,shared,default,reduction,if,copyin 等子句都可以在并行 区域编译制导语句中出现。在后面的叙述中,我们将介绍每一个子句的功能和作用。parallel 编译制导语句与循环 行化parallel for 语句类似,在使用到程序块之前也有一定的限制。 程序块必须是一个只有单一入口和单一出口的程序块,不能从外面转入到程序块的内部,也 不允许从程序块内部有多个出口转到程序块之外,在程序块内部的跳转是允许的。在程序块 内部直接调用exit 函数来退出整个程序的执行也是允许的。 parallel 编译制导语句的执行过程 为了理解编译制导语句parallel 语句的执行过程,我们先看看如下两个程序的执行结果。 这两个程序非常简单,且相似,唯一的不同之处在于前面一个程序的编译制导语句是 行区 域编译制导语句 parallel 而后面一个程序的编译制导语句是循环 行化的编译制导语句 parallel for。 代码5.11parallel 编译制导语句1 #pragma omp parallel for (int i=0;i5;i++) printf (hello world i=%d\n,i); 程序的执行结果: hello world i=0 hello world i=0 hello world i=1 hello world i=1 hello world i=2 hello world i=2 hello world i=3 hello world i=3 hello world i=4 hello world i=4 代码5.12parallel 编译制导语句2 #pragma omp parallel for for (int i=0;i5;i++) printf (hello world i=%d\n,i); 程序的执行结果: hello world i=0 hello world i=3 hello world i=1 hello world i=4 hello world i=2 可以看到,两个程序唯一的区别在于程序中黑体标出的 for。(在执行的过程中,环境变量 OMP_NUM_THREADS=2。)从这两个执行结果中我们可以明显地看到并行区域与循环并行化的区 别,即并行区域采用了复制执行的方式,将代码在所有的线程内部都执行一次;而循环并行 化则采用了工作分配的执行方式,将循环所需 的所有工作量按照一定的方式分配到各个执 行线程中,所有线程执行工作的总和是原先串行执行所完成的工作量。 总结上述的 行区域parallel 语句的作用是当程序遇到parallel 编译制导语句的时候,就 会生成相应数 (根据环境变量)的线程组成一个线程组, 将代码重复地在各个线程内部 执行。parallel 的末尾有一个隐含的同步屏障 (barrier),所有线程完成所需的重复任务 有,在这个同步屏障出会和(join)。此时,线程组的主线程 (master)继续执行,而相应 的子线程 (slave)则停止执行。 线程私有数据与threadprivate,copyin 子句 前面我们已经看到在循环并行化的过程中,有一套默认的规则用来控制变量在线程之间的共 享属性。除了private 子句能够产生线程私有的变量之外,还需 考虑一些全局的数据。这 些全局的数据可能是在整个程序运行过程中都需 的数据,或者是在源程序中跨多个文件所 需

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档