用openmp并行读入文本文件,运行时间比串行还长
想用openmp实现字符串匹配算法的并行,发现c语言读入文本时间较长,想优化一下,但是用openmp并行读入文件比原来的串行程序时间还长,十分不解,求指导。
用的4线程,并行时间0.43s,串行时间0.39s。运行都没问题的
在mac上跑的,线程数在编译的时候在terminal输进去,测试了没问题的
long thread_count=strtol(argv[1],NULL,10);
printf("%d\n",thread_count);
FILE *fp=fopen("/Users/liuchong/Desktop/Harry Potter.txt","r");
fseek(fp, 0L, SEEK_END);
long SIZE = ftell(fp);
fseek(fp, 0L, SEEK_SET);
char *text = (char*) malloc(sizeof(char) * SIZE);
if(!fp)
{
printf("can't open file\n");
return -1;
}
# pragma omp parallel for num_threads(thread_count)
for (int i=0; i<thread_count;i++)
{
fseek(fp,i*SIZE/thread_count,SEEK_SET);
long local_test=i*(SIZE/thread_count);
for(local_test;local_test<((i+1)*SIZE/thread_count);local_test++)
{
fscanf(fp,"%c",&text[local_test]);
}
}
//串行程序
/*
for(long j=0;j<SIZE;j++)
//while(!feof(fp))
{
fscanf(fp,"%c",&text[test]);
test++;
//printf("%s",text);
}
*/
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
其他的就不看了,单独看这里
你希望的是这一段代码能够并行运行,以便加快读取速度。
在这里达不到这个目的,原因我不敢妄下断言。
这里使用了
fscanf
,在编译的时候,如果编译的是多线程版本的程序,这个函数是会加锁的保证其线程安全的。如果编译的不是多线程程序,那么不会加锁。这个在
gcc
中是这样的,VS我想应该也是。加锁和解锁都需要时间,所以会慢也是正常的。你的线程呢?
omp_get_wtime用这个函数来记录时间。
包含#include <omp.h>
double time_sss = omp_get_wtime(); 这样再试试。