vc2010的支持好像很不错了,直接在 工程属性-》c++ -》 language 里面把 openmp设置为开启就可以了
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
QueryPerformanceCounter(&t0);
#pragma omp parallel for num_threads(2)
for
(
int
i=0; i< number; i++) {
THREAD_SAFE_TRACE(Trace::DEBUG <<
"DiameterSib::request (Diameter) in >"
<< var1 <<
" "
<< var2 <<
" "
<< var3 <<
" "
<< var4.c_str()<<
" "
<< var1 <<
" "
<< __DATE__ <<
"ddddddddddddddddddddddddd"
<< Trace::SEND);
}
QueryPerformanceCounter(&t1);
//printf("compare 1 : %d microseconds\n",
// ((t1.QuadPart-t0.QuadPart)*1000000)/freq.QuadPart);
int
time
= (((t1.QuadPart-t0.QuadPart)*1000000)/freq.QuadPart);
std::cout <<
"trace "
<< j <<
" 次, 耗时 "
<<
time
<<
" 微秒"
<< std::endl;
|
看看前面那个循环前面 #pragma omp parallel for num_threads(2) 语句,这样就自动把这个循环体并行执行了。 编译器自己会构建多个线程。
这里我指定线程数为2。 有了这个openmp就不用我自己写创建线程的那些代码了。 我这个测试主要是测试多线程的 log语句看看锁同步的影响。想启动多少个线程就直接在这里改数字,很方便啊。openmp用在我这个测试感觉很合适。
msdn的openmp指令的参考
http://msdn.microsoft.com/en-us/library/tt15eb9t(v=vs.100).aspx