1、使用两个线程完成两个文件的拷贝,分支线程1拷贝前一半,分支线程2拷贝后一半,主线程回收两个分支线程的资源
#include <myhead.h>
//文件信息结构体创建
struct File
{
const char *file1;//文件1地址
const char *file2;//文件2地址
int len;//文件1的大小
int loge;//自定义文件标示,辅助程序执行
};
//获取文件长度
int GetFileLen(const char *argv1, const char *argv2)
{
int src, dest;
if ((src = open(argv1, O_RDONLY)) == -1)
{
perror("src error");
return -1;
}
if ((dest = open(argv2, O_WRONLY | O_CREAT | O_TRUNC, 0664)) == -1)
{
perror("dest error");
return -1;
}
int size = lseek(src, 0, SEEK_END);//获取文件大小
close(src);
close(dest);
return size;
}
void *copy(void *argc)
{
int src, dest;
int len = ((struct File *)argc)->len;
if ((src = open(((struct File *)argc)->file1, O_RDONLY)) == -1)//判断文件src是否打开成功
{
perror("src error");
return NULL;
}
if ((dest = open(((struct File *)argc)->file2, O_WRONLY)) == -1)//判断文件dest是否打开成功
{
perror("dest error");
return NULL;
}
int num = 0, count = 0;
char buf[128];//定义搬运工
int loge = ((struct File *)argc)->loge;//获取传递进来的线程的loge
if (loge == 1)//判断如果是线程tid1执行这段
{
while (1)
{
count = read(src, buf, sizeof(buf));
num += count;
if (num > len / 2)
{
write(dest, buf, count - (num - len / 2));
break;
}
write(dest, buf, count);
}
}
else if(loge ==2)//判断如果是线程tid2执行这段
{
//光标偏移到文件一半的位置
lseek(src, len / 2, SEEK_SET);
lseek(dest, len / 2, SEEK_SET);
while (1)
{
count = read(src, buf, sizeof(buf));
if (count == 0)
{
break;
}
write(dest, buf, count);
}
}
close(src);
close(dest);
pthread_exit(NULL);//关闭线程
}
int main(int argc, const char *argv[])
{
pthread_t tid1, tid2;
int len = GetFileLen(argv[1], argv[2]);//获取文件大小
struct File file[2] = {{argv[1], argv[2], len, 1}, {argv[1], argv[2], len, 2}};//结构体的形式传递参数
if (pthread_create(&tid1, NULL, copy, &file[0]) != 0)//判断线程tid1是否打开成功
{
printf("tid1 error\n");
return -1;
}
if (pthread_create(&tid2, NULL, copy, &file[1]) != 0)//判断线程tid2是否打开成功
{
printf("tid2 error\n");
return -1;
}
printf("%d\n", len);
//回收线程
pthread_join(tid1, NULL);
pthread_join(tid2, NULL);
return 0;
}
思维导图