- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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 子句能够产生线程私有的变量之外,还需 考虑一些全局的数据。这
些全局的数据可能是在整个程序运行过程中都需 的数据,或者是在源程序中跨多个文件所
需
您可能关注的文档
- 不同形态的a!Fe2O3纳米粉体的水热合成表征及-中国表面活性剂网.PDF
- 不同心理韧性运动员对情绪信息的注意偏向研究-天津体育学院学报.PDF
- 不同尖晶石含量多孔方镁石G尖晶石陶瓷的抗水泥熟料侵蚀性能.PDF
- 不同改性剂对聚丙烯/碳酸钙复合材料性能的影响-应用化学.PDF
- 不同时期PGRs对大豆花荚脱落率及纤维素酶活性-中国油料作物学报.PDF
- 不同季节江蓠脱落物对大型海藻场上覆水的影响Effect-南方水产科学.PDF
- 不同挤压力下凝固的Al-Si-Cu-T4的组织与性能-中国有色金属学报.PDF
- 不同有机微量元素的区别.PDF
- 不同条件下介质阻挡放电的仿真与试验研究-OpenRepositoryof.PDF
- 不同水平短跑运动员途中跑支撑反作用力研究-武汉体育学院学报.PDF
最近下载
- DBJ∕T13-363-2021 福建省智慧杆建设技术标准.pdf VIP
- 2023年初级会计职称《经济法基础》精讲课件-第一章--总论.pptx VIP
- 科学教育出版社七年级上册劳动实践手册教案.docx VIP
- 建筑施工 - L17J104复合外模板现浇混凝土保温系统建筑构造(山东图集2018.1.1实施).pdf VIP
- 2023年初级会计职称《经济法基础》精讲课件--第二章-会计法律制度.pptx VIP
- 高中英语句子成分及简单句的五种基本句型课件(共47张PPT).ppt VIP
- 风管精品工程施工方案(3篇).docx VIP
- DLT 1572.3-2016 变电站和发电厂直流辅助电源系统短路电流 第3部分:算例.docx VIP
- 职业技术学院《三坐标智能测量技术》课程标准 机械制造及自动化专业.pdf VIP
- 《特种设备安全培训》精品课件(2024).pptx VIP
文档评论(0)