第一次试用vc2010的openmp功能, 多线程并行执行for循环

来源:互联网 发布:java的计算器源代码 编辑:程序博客网 时间:2024/04/30 21:54

原文地址:http://hi.baidu.com/widebright/item/83f648c365c79709c710b234


第一次试用vc2010的openmp功能, 多线程并行执行for循环

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


原创粉丝点击