#include <stdio.h>
#include <omp.h>
long long add(int x,int y){ //单线程计算函数
long long sum;
for(;x<=y;x++)sum+=x;
return sum;
}
long long ADD(int x,int y){ //多线程计算函数
long long s1,s2,s3,s4,s5,sum;
int temp=y/5;
#pragma omp parallel sections
{
#pragma omp section
s1=add(1,temp);
#pragma omp section
s2=add(temp+1,2*temp);
#pragma omp section
s3=add(2*temp+1,3*temp);
#pragma omp section
s4=add(3*temp+1,4*temp);
#pragma omp section
s5=add(4*temp+1,y);
}
sum=s1+s2+s3+s4+s5;
return sum;
}
void main(){
double start,end;
printf("计算1+2+...+100000000:\n");
start = omp_get_wtime();
printf("单线程计算结果为:%lld\n",add(1,100000000));
end = omp_get_wtime();
printf("单线程用时:%fs\n",(end - start));
start = omp_get_wtime();
printf("多线程计算结果为:%lld\n",ADD(1,100000000));
end = omp_get_wtime();
printf("多线程用时:%fs\n",(end - start));
}
运行结果:


本文探讨了使用C语言创建多线程进行数值求和的方法,并通过实际运行比较了不同线程数量下的计算时间,展示了多线程在并行计算上的优势。
最低0.47元/天 解锁文章
686

被折叠的 条评论
为什么被折叠?



