feiduoge 2020-08-06 11:36 采纳率: 0%
浏览 467

C++ Openmp #pragma omp for

    int i = 0;
    int total = 0;
#pragma omp parallel
    {
        int iID = omp_get_thread_num();
        printf("1.I am Thread %d\n", omp_get_thread_num());
#pragma omp for
        for (i = 0; i < 20000; i++)
        {
            total += i;
            int iID = omp_get_thread_num();
            printf("2.I am Thread %d\n", omp_get_thread_num());
        }
    }
    std::cout << "OpenMP total:" << total<< std::endl;

上面的代码计算得到的total结果是正确的(重复跑过多次),并且for循环也是多线程跑的,我的问题是在total+=i的时候,我不需要用原子或者临界区去控制吗?

  • 写回答

2条回答 默认 最新

  • threenewbee 2020-08-06 12:03
    关注
    #pragma omp for
    放在了循环的开头,编译器会自动处理同步。
    
    评论

报告相同问题?