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); #pragmaompparallelfornum_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("compare1:%dmicroseconds\n", //((t1.QuadPart-t0.QuadPart)*1000000)/freq.QuadPart);
int time =(((t1.QuadPart-t0.QuadPart)*1000000)/freq.QuadPart);
std::cout<< "trace" <<j<< "次,耗时" << time << "微秒" <<std::endl;
|
看看前面那个循环前面#pragmaompparallelfornum_threads(2)语句,这样就自动把这个循环体并行执行了。编译器自己会构建多个线程。
这里我指定线程数为2。有了这个openmp就不用我自己写创建线程的那些代码了。我这个测试主要是测试多线程的log语句看看锁同步的影响。想启动多少个线程就直接在这里改数字,很方便啊。openmp用在我这个测试感觉很合适。
msdn的openmp指令的参考
http://msdn.microsoft.com/en-us/library/tt15eb9t(v=vs.100).aspx