1>使用两个线程完成两个文件的拷贝,分支线程1拷贝前一半,分支线程2拷贝后一半,主线程回收两个线程的资源
#include<myhead.h>
struct Buf
{
const char *srcfile;
const char *destfile;
int start;
int sum;
};
//创建求源文件大小的函数
int get_file_len(const char *srcfile, const char *destfile)
{
//以只读的形式打开源文件
int sfd=open(srcfile,O_RDONLY);
if(sfd==-1)
{
perror("open srcfile error");
return -1;
}
//以只写的形式打开目标文件
int dfd=open(destfile,O_WRONLY|O_CREAT|O_TRUNC,0664);
if(dfd==-1)
{
perror("open destfile error");
return -1;
}
int size=lseek(sfd,0,SEEK_END);
//关闭文件
close(sfd);
close(dfd);
return size;
}
//定义文件拷贝函数
void copy_file(const char*srcfile,const char *destfile,int start,int sum)
{
//以只读的形式打开源文件
int sfd=open(srcfile,O_RDONLY);
if(sfd==-1)
{
perror("open srcfile error");
}
//以创建的形式打开目标文件
int dfd=open(destfile,O_WRONLY);
if(dfd==-1)
{
perror("open destfile error");
return;
}
//移动光标位置
lseek(sfd,start,SEEK_SET);
lseek(dfd,start,SEEK_SET);
//定义搬运工
char buf[128]="";
int count=0;
while(1)
{
//从源文件中读取信息
int res=read(sfd,buf,sizeof(buf));
//将读取的数据累加
sum+=res;
if(res==0||count>sum)
{
write(dfd,buf,res-(count-sum));
break;
}
//写入目标文件中
write(dfd,buf,res);
}
//关闭文件
close(sfd);
close(dfd);
}
//线程1拷贝前一半函数
void *task1(void *arg)
{
struct Buf *b=(struct Buf*)arg;
copy_file(b->srcfile,b->destfile,b->start,b->sum);
pthread_exit(NULL);
}
//线程2拷贝后一半函数
void *task2(void *arg)
{
struct Buf *b=(struct Buf*)arg;
copy_file(b->srcfile,b->destfile,b->start,b->sum);
pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{
//判断传入的数据是否为3个
if(argc!=3)
{
printf("input file error");
}
int len=get_file_len(argv[1],argv[2]);
//定义线程变量
pthread_t tid1,tid2;
//封装要传入的数据
struct Buf buf1={argv[1],argv[2],0,len/2};
struct Buf buf2={argv[1],argv[2],len/2,len-len/2};
//线程1
if(pthread_create(&tid1,NULL,task1,&buf1)!=0)
{
printf("创建失败\n");
return -1;
}
//线程2
if(pthread_create(&tid2,NULL,task2,&buf2)!=0)
{
printf("创建失败\n");
return -1;
}
//回收分支线程资源
pthread_join(tid1,NULL);
pthread_join(tid2,NULL);
printf("拷贝成功\n");
return 0;
}
2>思维导图