日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

openMP的简单使用

發(fā)布時間:2024/7/23 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 openMP的简单使用 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

安裝,參考:https://blog.csdn.net/augusdi/article/details/8808226
如圖所示,右鍵工程名->屬性->C/C+±>語言,找到OpenMP支持,更改設(shè)置即可。

代碼編程,參考:https://blog.csdn.net/zhongkejingwang/article/details/40350027
在C/C++中使用OpenMP優(yōu)化代碼方便又簡單,代碼中需要并行處理的往往是一些比較耗時的for循環(huán),所以下面介紹一下OpenMP中for循環(huán)的應(yīng)用。
###1. 首先,如何使一段代碼并行處理呢?
omp中使用parallel制導指令標識代碼中的并行段,形式為:

#pragma omp parallel {...//每個線程都會執(zhí)行大括號里的代碼 }

我們編寫如下的代碼:

#include <iostream> #include "omp.h" using namespace std; int main(int argc, char **argv) {//設(shè)置線程數(shù),一般設(shè)置的線程數(shù)不超過CPU核心數(shù),這里開4個線程執(zhí)行并行代碼段omp_set_num_threads(4);#pragma omp parallel{cout << "Hello" << ", I am Thread " << omp_get_thread_num() << endl;} }

上面的代碼輸出結(jié)果為:

Hello,Thread Hello,Thread 21 Hello,Thread 3 Hello,Thread 0

可以看到四個線程各自獨立的輸出了cout后面的內(nèi)容。如果去掉omp_set_num_threads(4)語句,我們的電腦CPU的每個核都會獨立執(zhí)行,我的CPU有8個核,就會執(zhí)行8次大括號內(nèi)的語句。
###2.帶有for的制導指令:
使用形式為:

#pragma omp parallel for for()

或者

#pragma omp parallel { //注意:大括號必須要另起一行#pragma omp forfor() }

第一種形式作用域只是緊跟著的那個for循環(huán),而第二種形式在整個并行塊中可以出現(xiàn)多個for制導指令。

... #include "omp.h" ... int main() {omp_set_num_threads(4);#pragma omp parallel forfor (int i = 0; i < 6; i++){printf("i = %d,Hello,Thread:%d\n", i, omp_get_thread_num());}return 0; }

輸出結(jié)果如下:

i = 0,Hello,Thread:0 i = 1,Hello,Thread:0 i = 2,Hello,Thread:1 i = 3,Hello,Thread:1 i = 5,Hello,Thread:3 i = 4,Hello,Thread:2

我們可以看到輸出6次printf的任務(wù)被分給了CPU的4個核。
###3.數(shù)據(jù)同步問題

int main() {int n = 100000;int sum = 0;omp_set_num_threads(4);#pragma omp parallel forfor (int i = 0; i < n; i++){sum++;}cout << sum << endl;return 0; }

期望的正確結(jié)果是100000,但是這樣寫是錯誤的。看代碼,由于默認情況下sum變量是每個線程共享的,所以多個線程同時對sum操作時就會因為數(shù)據(jù)同步問題導致結(jié)果不對,顯然,輸出結(jié)果每次都不同,這是無法預(yù)知的,下面是輸出結(jié)果,但是每個線程不會共享for循環(huán)中的變量,包括i值。所以如果線程要調(diào)用for循環(huán)外的變量,要加critical語句,下面有介紹。

//多次輸出結(jié)果 58504 45203 35716 ...

#####解決方法1:方法一:對操作共享變量的代碼段做同步標識

int main() {int n = 100000;int sum = 0;omp_set_num_threads(4);#pragma omp parallel forfor (int i = 0; i < n; i++){#pragma omp critical{sum++;}}cout << sum << endl;return 0; }

critical制導語句標識的下一行代碼,也可以是跟著一個大括號括起來的代碼段做了同步處理。
輸出結(jié)果100000。

總結(jié)

以上是生活随笔為你收集整理的openMP的简单使用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。