程序简单来说类似一个多线程下载器,开了1024个线程,然后并发去服务器读取一个大文件的某一块,读取完成后,文件合并要按照顺序写文件,所以我采用了pthread_join依次等待上一个线程写完成操作。测试时候发现程序偶尔会突然down掉,也不出core,并不是总down,也会有成功执行时候。机器配制足够高了,内存96G,24核cpu。。。希望大家帮忙分析下。。谢谢,代码逻辑如下。
void* thread_fun()
{
......
if(id != 0)pthread_join(thread_list[id - 1],NULL);//等待上一个线程结束
write(fd,th_d->file,file - th_d->file);//写文件
}