华清IOday5 24-8-1

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;
}

思维导图

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值