自学内容网 自学内容网

多线程习题

1.使用两个线程完成两个文件的拷贝,分支线程1拷贝前一半,分支线程拷贝后一般,主线程回收两个分支线程的资源

#include<myhead.h>
struct Buf
{
const char *srcfile;
const char *destfile;
int start;
int len1;
};


//创建求源文件大小的函数
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 len)
{
//以只读的形式打开源文件
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 sum=0;
while(1)
{
//从源文件中读取信息
int res=read(sfd,buf,sizeof(buf));
//将读取的数据累加
sum+=res;
if(res==0||sum>len)
{
write(dfd,buf,res-(sum-len));
break;
}
//写入目标文件中
write(dfd,buf,res);
}
//关闭文件
close(sfd);
close(dfd);
printf("拷贝成功\n");
}
void *task1(void *arg)//拷贝前一半
{
struct Buf *b=(struct Buf*)arg;
copy_file(b->srcfile,b->destfile,b->start,b->len1);
pthread_exit(NULL);
}
void *task2(void *arg)//拷贝后一半
{
struct Buf *b=(struct Buf*)arg;
copy_file(b->srcfile,b->destfile,b->start,b->len1);
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};

//创建两个线程
if(pthread_create(&tid1,NULL,task1,&buf1)!=0)
{
printf("tid1创建失败\n");
return -1;
}
if(pthread_create(&tid2,NULL,task2,&buf2)!=0)
{
printf("tid2,创建失败\n");
return -1;
}
//阻塞等待线程的结束
pthread_join(tid1,NULL);
pthread_join(tid2,NULL);
return 0;
}

思维导图:


原文地址:https://blog.csdn.net/gjvrnv/article/details/140854678

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!