如何在OpenMP中并行化for循环?

时间:2014-01-20 05:12:23

标签: multithreading gcc openmp

这是我的程序,它计算分配给1的10000个元素的总和。第一个螺纹的总和应该是5000,而其他的则为5000,但是对于每次运行,它给出不同的输出

#include<omp.h>
#include<stdio.h>
int main()
{
int i,sum1=0,sum2=0,a[10000],sum_final=0;
for(i=0;i<10000;i++)
{
    a[i]=1;
}
#pragma omp parallel
{
    if(omp_get_thread_num()==0)
    {
        for(i=0;i<5000;i++)
        {
            sum1+=a[i];
        }
        printf("Sum1 is %d\n",sum1);
    }
    if(omp_get_thread_num()==1)
    {
        for(i=5000;i<10000;i++)
        {
            sum2+=a[i];
        }
        printf("Sum2 is %d\n",sum2);
    }
}
return 0;
}

1 个答案:

答案 0 :(得分:2)

你的循环计数器应该是私有的。我想你应该试试

#pragma omp parallel private(i)