Linux下C语言实现多线程排序文件内容

一、要求及主要函数

  • 使用多线程,编写一个并行程序,将目录中的多个文件里的内容进行排序。
  • 文件内容格式为: <数字><空格><数字> 例如: 0 1 2 3 4 5 6 7 8
  • 定义全局变量存储给定目录下的多个(现假设有10个)文件的地址
  • 文件名从0到9,当前有两个线程, 0号线程排序0 2 4 6 8号文件, 1号线程排序1 3 5 7 9号文件

pthread_create

功能

  pthread_create是UNIX环境创建线程函数

函数原型

  int pthread_create(pthread_t *restrict tidp,const pthread_attr_t *restrict_attr,void*(*start_rtn)(void*),void *restrict arg);

  第一个参数为指向线程标识符的指针。

  第二个参数用来设置线程属性。

  第三个参数是线程运行函数的地址。

  最后一个参数是运行函数的参数。

返回值

  若成功则返回0,否则返回出错编号

pthread_join

功能

  函数pthread_join用来等待一个线程的结束。

函数原型

  extern int pthread_join __P (pthread_t __th, void **__thread_return);

  第一个参数为被等待的线程标识符

  第二个参数为一个用户定义的指针,它可以用来存储被等待线程的返回值。

注意

    这个函数是一个线程阻塞的函数,调用它的函数将一直等待到被等待的线程结束为止,当函数返回时,被等待线程的资源被收回。如果执行成功,将返回0,如果失败则返回一个错误号。

 

这两函数的头文件为 #include,在编译时需加上-lpthread参数,以调用静态链接库。因为pthread并非Linux系统的默认库。 

 

二、主要代码

#include 
#include 
#include 
#include
#include 
#include 
#include 
static pthread_t id1,id2;
static char filePathList[10][100];//存放文件路径
//qsort比较器
int cmp(const void *a, const void *b) {
	return (*(int *)a - *(int *)b);
}
//线程1,排序0、2、4、6、8
void funOne(int thread_num) {
	printf("Thread: %d running...\n",thread_num);

	//先读取文件里内容后排序,最后覆盖写入
	FILE *fp;
	int index=0;//开始的文件下标
	while(index<10) {
		fp=fopen(filePathList[index],"r");//只读
		int t[1024];//存放读取的文件内容
		int i=0,j;
		printf("Thread %d 读取%d文件内容:\n",thread_num,index);
		while(fscanf(fp,"%d",&t[i])>0) {// 读取数字
			printf("%d ",t[i]);
			i++;
		}
		printf("\n");
		fclose(fp);

		qsort(t,i,sizeof(t[0]),cmp);//排序文件内容
		
		printf("Thread %d 排序后%d文件内容:\n",thread_num,index);
		fp=fopen(filePathList[index],"w");//覆写
		for(j=0; j0) {//读取数字
			printf("%d ",t[i]);
			i++;
		}
		printf("\n");
		fclose(fp);

		qsort(t,i,sizeof(t[0]),cmp);//排序文件内容
		
		printf("Thread %d 排序后%d文件内容:\n",thread_num,index);
		fp=fopen(filePathList[index],"w");//覆写
		for(j=0; j

三、运行截图

首先需要10个要排序的文件,程序执行后会将排序好的内容覆盖掉原来的文件内容

Linux下C语言实现多线程排序文件内容_第1张图片

多线程并发执行下,每次打印的信息不太一样,但最终保存到文件的排序结果是一样的 。

Linux下C语言实现多线程排序文件内容_第2张图片   Linux下C语言实现多线程排序文件内容_第3张图片

四、总结

该程序用到了存储路径的全局变量,而且每个线程处理的文件没有冲突,所以代码里不需要互斥锁或条件变量来实现。

你可能感兴趣的:(Linux)