(原創) 如何在VC8使用OpenMP? (C/C++) (VC++) (OpenMP)

Abstract
隨著多核心CPU普及,但時脈卻越來越低,若程式還是用單核心的方式去寫,不僅壓榨不出多核心的效能,執行速度還可能越來越低,所以使用平行處理(Parallel Programming)也就越來越重要了。

Introduction
相信很多人都有感覺,換了Core 2 Duo後,發現執行速度並沒有Pentium IV來的快,主要是因為Core 2 Duo的時脈都沒Pentium IV高,若程式還是用單核心的寫法,並無法發揮出多核心的效能。OpenMP可以讓你簡單的撰寫平行化的程式,盡量榨乾多核心CPU,讓你的程式跑得更快,如7Zip就是一個很好的例子,在多核心下壓縮速度驚人,遠遠超越WinRAR。

OpenMP on VC8
OpenMP是Intel提出的標準,目前已經被Visual C++和gcc所支援,所以可以利用OpenMP撰寫出跨平台的平行化程式。

Step 1:
設定支援OpenMP

選擇專案名稱,右鍵Properties,左側Configuration Properties -> C/C++ -> Language,右側將OpenMP Support選Yes(/openmp)

OpenMP00

Step 2:
測試Hello World平行處理版

C語言

1 /* 
2 (C) OOMusou 2008 http://oomusou.cnblogs.com
3 
4 Filename    : parallel_helloworld.cpp
5 Compiler    : Visual C++ 8.0
6 Description : Demo how to use hello world in parallel programming
7 Release     : 03/05/2008 1.0
8 */
9 #include <stdio.h>
10 #include "omp.h"
11 
12 int main() {
13   printf("Number of core : %d\n", omp_get_num_procs());
14   printf("Number of threads : %d\n", omp_get_num_threads());
15    
16   #pragma omp parallel for
17   for(int i = 0; i < 16; ++i) {
18     printf("thread %d print Hello World!!\n", omp_get_thread_num());
19   } 
20 }


執行結果

Number of core : 2
Number of threads :
1
thread
0 print Hello World!!
thread
1 print Hello World!!
thread
0 print Hello World!!
thread
0 print Hello World!!
thread
1 print Hello World!!
thread
0 print Hello World!!
thread
0 print Hello World!!
thread
1 print Hello World!!
thread
0 print Hello World!!
thread
1 print Hello World!!
thread
0 print Hello World!!
thread
1 print Hello World!!
thread
0 print Hello World!!
thread
1 print Hello World!!
thread
1 print Hello World!!
thread
1 print Hello World!!


若能執行成功,表示已經在VC8設定出OpenMP的執行環境。

和ANSI C不同的是,第10行多了#include "omp.h",這是OpenMP的header file,在16行多了#pragma directive,表示以下的for loop需要平行化,如此一來我們可以發現Hello World分別以兩個thread進行列印,充分利用了兩個核心。

Conclusion
我覺得OpenMP最大的貢獻在於,只需對原本單核心的程式做小幅度的修改,就變成可以支援多核心的程式,而且又是個開放的標準,所以可移植性沒問題。

posted on 2008-03-05 12:43  真 OO无双  阅读(4919)  评论(6编辑  收藏  举报

导航