OpenMP笔记(三)
个人博客地址:http://www.bearoom.xyz/2019/02/21/openmp3/
这一部分主要记录一些指令的使用。
一、parallel的使用
parallel是用于构造并行块的,也可以和for、sections等指令一起使用。在C/C++中,parallel的使用方法如下 :
```
#pragma omp parallel [for | sections] [子句[子句]…]
{
//代码
}
```
一个例子:
#pragma omp parallel
{
printf("Hello, World!, ThreadId = %d\n", omp_get_thread_num());
}
这段代码中的打印会执行四次,说明开了四个线程,当然可以修改默认的线程数,通过函数来设置或者指令来修改,如:
omp_set_num_threads(8);
#pragma omp parallel
{
printf("Hello, World!, ThreadId = %d\n", omp_get_thread_num());
}
或者:
#pragma omp parallel num_threads(8)
{
printf("Hello, World!, ThreadId = %d\n", omp_get_thread_num());
}
二、for的使用
for的使用是将for循环分配到多个线程中执行,一般for要跟parallel一起使用才有效,单独使用for一般是无效的。
单独使用for指令的情况,可以看到,即使设置了8个线程,依然是无效的:
#pragma omp for
for (int i = 0; i < 8; i++)
{
printf("Hello, World!, ThreadId = %d\n", omp_get_thread_num());
}

与parallel的结合使用方法1:
omp_set_num_threads(8);
#pragma omp parallel for
for (int i = 0; i < 8; i++)
{
printf("Hello, World!, ThreadId = %d\n", omp_get_thread_num());
}

与parallel的结合使用方法2:
omp_set_num_threads(8);
#pragma omp parallel
#pragma omp for
for (int i = 0; i < 8; i++)
{
printf("Hello, World!, ThreadId = %d\n", omp_get_thread_num());
}
或者,将#pragma omp parallel后面要并行的部分用大括号括起来,此时大括号中可以写多个for循环,且每个for循环前面都要写#pragma omp for,每个for循环之间是串行的,for循环里面是并行的:
omp_set_num_threads(8);
#pragma omp parallel
{
#pragma omp for
for (int i = 0; i < 8; i++)
{
printf("Hello, World!, ThreadId = %d\n", omp_get_thread_num());
}
}

三、sections和section指令的用法
section语句是要用在sections语句中的,将不同的语句分段执行,sections的用法与for类似:
```
#pragma omp parallel sections
{
#pragma omp section
printf("section 1 ThreadId = %d \n", omp_get_thread_num());
#pragma omp section
printf("section 2 ThreadId = %d \n", omp_get_thread_num());
#pragma omp section
printf("section 3 ThreadId = %d \n", omp_get_thread_num());
#pragma omp section
printf("section 4 ThreadId = %d \n", omp_get_thread_num());
}
```

一树春风千万枝,
嫩于金色软于丝。
永丰西角荒园里,
尽日无人属阿谁?
–白居易 《杨柳枝词》
OpenMP笔记(三)的更多相关文章
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- 《CMake实践》笔记三:构建静态库(.a) 与 动态库(.so) 及 如何使用外部共享库和头文件
<CMake实践>笔记一:PROJECT/MESSAGE/ADD_EXECUTABLE <CMake实践>笔记二:INSTALL/CMAKE_INSTALL_PREFIX &l ...
- Mastering Web Application Development with AngularJS 读书笔记(三)
第一章笔记 (三) 一.Factories factory 方法是创建对象的另一种方式,与service相比更灵活,因为可以注册可任何任意对象创造功能.例如: myMod.factory('notif ...
- Python 学习笔记三
笔记三:函数 笔记二已取消置顶链接地址:http://www.cnblogs.com/dzzy/p/5289186.html 函数的作用: 給代码段命名,就像变量給数字命名一样 可以接收参数,像arg ...
- 《MFC游戏开发》笔记三 游戏贴图与透明特效的实现
本系列文章由七十一雾央编写,转载请注明出处. 313239 作者:七十一雾央 新浪微博:http://weibo.com/1689160943/profile?rightmod=1&wvr=5 ...
- [Firefly引擎][学习笔记三][已完结]所需模块封装
原地址:http://www.9miao.com/question-15-54671.html 学习笔记一传送门学习笔记二传送门 学习笔记三导读: 笔记三主要就是各个模块的封装了,这里贴 ...
- JSP学习笔记(三):简单的Tomcat Web服务器
注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...
- 构建高性能WEB站点笔记三
构建高性能WEB站点笔记三 第10章 分布式缓存 10.1数据库的前端缓存区 文件系统内核缓冲区,位于物理内存的内核地址空间,除了使用O_DIRECT标记打开的文件以外,所有对磁盘文件的读写操作都要经 ...
- Git 笔记三 Git的初步使用
Git 笔记三 Git的初步使用 在上一篇中,学习了如何配置Git环境,这一篇,开始学习Git的初步使用.Git的初步使用还是很简单的.总体上知道git init, git clone, git ad ...
随机推荐
- CodeForces - 755B PolandBall and Game(博弈)
题意:A和B两人每人都熟悉一些单词.A先开始,每人说一个单词,单词不能与两人之前说过的所有单词重复,谁无话可说谁输.两人可能有共同会的单词. 分析:因为要让对方尽量无单词可说,所以每个人优先说的都是两 ...
- C++(五)构造函数
//构造函数的作用:就是在函数被创建时使用特定的值构造对象,将对象初始化为一个特定的初始状态//例如在构造一个clock类对象的时候,将初始的时间设定为0:0:0//构造函数的名必须与类名相同,不能定 ...
- .NET 一次读取几百条数据优化,从原来30分钟优化到30秒
1.全部数据读取到内存, 不要使用string,而是使用stringbuilder,stringbuilder的效率非常高 2.添加到数据库 不要使用excute,而是使用事务,几百万条数据会请求数据 ...
- 用Git管理项目进行版本控制
一.安装 1.1windows 要在Windows系统中安装Git,请访问http://msysgit.github.io/,并单击Download.安装. 1.2 在 Linux 系统中安装 Git ...
- Windows系统安装免费的开源虚拟机软件VirtualBox
https://www.qikegu.com/uncategorized/1179 VirtualBox是什么 VirtualBox是一个虚拟机平台软件,在VirtualBox平台上可以安装各种操作系 ...
- 我学到的treap
到目前为止,平衡树应该是我学过的数据结构里面最难的一个了.(顺便贴上一个我认为treap讲解的比较好的博客https://blog.csdn.net/u014634338/article/detail ...
- css渐变实现
body{ width: 100%; height: 100%; overflow: hidden; } *{ margin: 0px; padding: 0px; font-size: 0px; } ...
- 资源的合并与压缩-html压缩
资源的合并:减少http请求数量 资源的压缩:减少请求资源的大小 html压缩 html代码压缩就是压缩这些在文本文件中有意义,但是在html中不显示的字符,包括空格,制表符,换行符等,还有一些其他意 ...
- Django——URL详解/Django中URL是如何与urls文件匹配的
URL标准语法 protocol://hostname[:port]/path/[:parameters][?query]#fragment https://i.cnblogs.com/EditPos ...
- OI常用模板
long long qpow(long long a,long long b,int mod) { ; while (b) { ) res=res*a%mod; a=a*a%mod; b>> ...