简单了解OpenMP

OpenMP 是 Open MultiProcessing 的缩写。OpenMP 并不是一个简单的函数库,而是一个诸多编译器支持的框架,或者说是协议吧,总之,不需要任何配置,你就可以在 Visual Studio 或者 gcc 中使用它了。


#pragma omp parallel

vs中配置

很多需要并行的代码用for写起来会比较痛苦,这时可以用“#pragma omp parallel sections”标示将要并行执行的代码括起来,然后用”#pragma omp section”标示每一条线程的执行代码

设置环境变量,我的电脑->属性->高级->环境变量,新建一个 OMP_NUM_THREADS变量,值设为2,即为程序执行的线程数

在环境变量中设置 OMP_NUM_THREADS变量,值设为8,那么就是8线程了(重新设置环境变量后,需要重启vs)

大多数情况下,我们主要会将多线程技术应用在循环中而不是全部代码。OpenMP主要被应用于for循环的多线程处理,这主要还是因为for循环比较容易控制。当然如果你非要用在while循环上也不是不可以,只不过要大量修改你的代码然后用一个block来圈在while之外,总之是一个比较另类的操作了。

#include <iostream>#include "omp.h"using namespace std;
int main(int argc, char **argv) {
        //设置线程数,一般设置的线程数不超过CPU核心数,这里开4个线程执行并行代码段
        omp_set_num_threads(4);
#pragma omp parallel
        {
                cout << "Hello" << ", I am Thread " << omp_get_thread_num() << endl;
        }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值