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