一、使用多线程完成两个文件的拷贝,第一个线程拷贝前一半,第二个线程拷贝后一半,主线程回收两个线程的资源。
代码:
#include<myhead.h>
typedef struct //类型重定义结构体
{
const char *src;
const char *dest;
int start;
int len;
}mess;
int get_file_len(mess *messmcp);
void *multi_cp(void *arg);
int main(int argc, const char *argv[])
{
if(argc!=3)
{
puts("input file error");
puts("usage:./a.out srcfile destfile");
return -1;
}
mess m={argv[1],argv[2],0,0};//初始化结构体成员的值
mess *messmcp=&m;//定义结构体指针
get_file_len(messmcp);//创建文件 并求要复制文件的字节大小存入结构体len内
int Lenth=messmcp->len;//保存总大小
messmcp->len=Lenth-Lenth/2;//第一次复制前修改结构体内容
messmcp->start=Lenth/2;
pthread_t tid;
if(pthread_create(&tid,NULL,multi_cp,messmcp)!=0)
{
puts("tid create error\n");
return -1;
}
if(pthread_join(tid,NULL)==0)//回收第一个线程;
{
puts("reclaim thread1");
}
messmcp->len=Lenth/2;//第二次拷贝前修改内容
messmcp->start=0;
if(pthread_create(&tid,NULL,multi_cp,messmcp)!=0)
{
puts("tid create error\n");
return -1;
}
if(pthread_join(tid,NULL)==0)//回收第二次的线程
{
puts("reclaim thread2");
}
puts("cp success");提示完成
return 0;
}
int get_file_len(mess *messmcp)
{
int srcfd,destfd;
if((srcfd=open(messmcp->src,O_RDONLY))==-1||(destfd=open(messmcp->dest,O_RDONLY|O_CREAT|O_TRUNC,0664))==-1)
{
perror("open error");
return -1;
}
messmcp->len=lseek(srcfd,0,SEEK_END);//获取文件大小
close(srcfd);
close(destfd);
return 0;
}
void *multi_cp(void *arg)//拷贝函数
{
mess *messmcp=(mess *)arg;
int srcfd,destfd;
if((srcfd=open(messmcp->src,O_RDONLY))==-1 || (destfd=open(messmcp->dest,O_WRONLY))==-1)
{
perror("open error");
return NULL;
}
lseek(srcfd,messmcp->start,SEEK_SET);//根据结构体内元素 定位光标位置
lseek(destfd,messmcp->start,SEEK_SET);
char buf[64]="";
int sum=0;
while(1)
{
int res=read(srcfd,buf,sizeof(buf));
sum+=res;
if(sum>=messmcp->len||res==0)
{
write(destfd,buf,res-(sum-messmcp->len));
break;
}
write(destfd,buf,res);
}
close(srcfd);
close(destfd);
puts("multi_cp run one");//每次运行至此提示拷贝一次
pthread_exit(NULL);//退出线程
}
运行图:
思维导图: