OpenMP是指导并行编译的编译方案,可以在通过编译指令的方式指导多核并行运算。
最大的优点莫过于其傻瓜式的使用方法,学习代价低。
通过一个简易的demo来说明:
(VS2013中编译运行)
#include <iostream>
#include <thread>
#include <windows.h>
void show_num(int num)
{
std::thread::idthreadId = std::this_thread::get_id();
std::cout<< "this is thread " << threadId;
std::cout<< " num: " << num<< std::endl;
}
int main(int argc, char** agrv)
{
for(int i = 0; i<20; i++)
{
show_num(i);
}
return0;
}
上述代码段仅完成数字0-19的打印工作,运行结果如下图:
接下来加入编译指令:#pragma omp parallel for
使用时需放在for语句前方,且仅对其后的for语句起作用,注意若两者之间有其他语句会报错。
如下:
#include <iostream>
#include <thread>
#include <windows.h>
void show_num(int num)
{
std::thread::idthreadId = std::this_thread::get_id();
std::cout<< "this is thread " << threadId;
std::cout<< " num: " << num<< std::endl;
}
int main(int argc, char** agrv)
{
#pragma omp parallel for
for(int i = 0; i<20; i++)
{
show_num(i);
}
return 0;
}
此时需要注意的是VS中使用OpenMP时需要对项目进行配置,若没有进行配置程序则会退化到串行执行。
也就是说仅加入一句编译指令而没配置OpenMP,程序运行结果不会发生任何改变。
配置方法如下:
首先在项目上点鼠标右键并打开最下方的属性一栏,
然后找到配置属性-> C/C++-> 语音,将右侧的OpenMP支持选为“是”。
配置完后再来看上述程序的运行结果:
此时有两个线程在跑,说明程序运行没问题。
另外上图中有两行换行符没有起作用,这是多个线程并行打印时产生的覆盖作用。
顺便说一句,查看电脑cpu核数目的方法:
打开任务管理器,选择性能一栏,CPU使用记录下有几个小窗口,cpu就有几个核,本电脑为2核。