当前位置: 代码迷 >> 综合 >> OpenMp 个人笔记(一)
  详细解决方案

OpenMp 个人笔记(一)

热度:24   发布时间:2023-12-15 13:35:16.0

1先来个HelloWorld

OpenMP是一个非常好用的并行编程的库,在我们的Windows平台上,只要下载了mingw(gomp)就可以使用了,可以说配置起来很方便,配合GCC来进行C语言的并行程序开发也是一件非常爽的事情啦。下面给出一个在网上找到的OpenMP的代码,并且用GCC编译来看看效果如何。

Noname1.c代码:

#include <omp.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void test()
{int a=0;clock_t t1=clock();for(int i=0;i<100000000;i++){a=i+1;}clock_t t2=clock();printf("Time = %d\n",t2-t1);
}
int main(int argc, char* argv[]) {clock_t t1=clock();#pragma omp parallel for for(int j=0;j<2;j++){test();}clock_t t2= clock();printf("Total time: %d\n",t2-t1);test();return 0;
}

编译的命令行:

gcc -std=c99 -fopenmp Noname1.c -o hello.exe
pause

这里要加上-fopenmp,-o可以指定输出的文件名,默认的是a.exe。

在笔者的破机子上这个代码跑出来的结果是

time=600

time=690

totaltime=700

time=660

totaltime 是两个test并行执行的时间,最后一个time是一个test执行的时间,可以看到这个效果还是不错的。关键我们几乎什么都没干,只不过在for循环上加了一条类似注释而已。因为笔者还要写论文,靠着并行计算的名头来忽悠毕业,所以还是先扯一点OpenMP的概念吧。

2 fork/join模式

openmp是的卖点是“共享式存储”并行,笔者现在还不是非常明白她的运作机理。而所谓的fork/join模式是说要等并行程序执行完成之后才能执行后面的非并行部分,不知道这和fork,join有什么关系? 相当于主线程创建的线程是不会和主线程一起并行执行的。