902作业

cs 复制代码
#include<myhead.h>
int main(int argc, const char *argv[])
{
	pid_t pid = -1;
	int fd1 = -1;
	int fd2 = -1;
	int num=0;
	ssize_t s;
	if (argc!=3)
	{
		printf("输入格式错误\n");
		return -1;
	}
	pid = fork();
	if ((fd1 = open(argv[1],O_RDONLY))==-1)
	{
		printf("源文件打开失败\n");
		return -1;
	}
	printf("源文件打开成功\n");

	off_t len = lseek(fd1,0,SEEK_END);

	lseek(fd1,0,SEEK_SET);

	close(fd1);
	if (pid>0)
	{
		printf("父进程:%d,拷贝前一半的内容\n",getpid());
		if ((fd1 = open(argv[1],O_RDONLY))==-1)
		{
			printf("源文件打开失败\n");
			return -1;
		}
		printf("源文件打开成功\n");

		if ((fd2 = open(argv[2],O_RDWR|O_CREAT|O_TRUNC))==-1)
		{
			printf("目标文件打开失败\n");
			return -1;

		}
		printf("目标文件打开成功\n");

		char str[128]="";
		while (num<(len/2)&&(s=read(fd1,str,sizeof(str)>(len/2-num)?(len/2-num):sizeof(str)))!=0)
		{
			write(fd2,str,s);
			num=s+num;
			bzero(str,sizeof(str));
			
		}
		
		close(fd1);
		close(fd2);

		wait(NULL);
		printf("已经成功回收\n");
	}
	else if (pid==0)
	{
		num=0;
		printf("子进程:%d,拷贝后一半的内容\n",getpid());
		if ((fd1 = open(argv[1],O_RDONLY))==-1)
		{
			printf("源文件打开失败\n");
			return -1;
		}
		printf("源文件打开成功\n");

		if ((fd2 = open(argv[2],O_WRONLY|O_CREAT|O_APPEND))==-1)
		{
			printf("目标文件打开失败\n");
			return -1;

		}
		printf("目标文件打开成功\n");

		lseek(fd1,len/2,SEEK_SET);
		lseek(fd2,len/2,SEEK_SET);

		char str[128]="";

		while (num<(len-(len/2))&&(s=read(fd1,str,sizeof(str)>(len/2-num)?(len/2-num):sizeof(str)))!=0)
		{
			write(fd2,str,s);
			num=s+num;
			bzero(str,sizeof(str));
		}
		
		printf("子进程已拷贝\n");
		close(fd1);
		close(fd2);
		exit(EXIT_SUCCESS);
	}

	return 0;
}
cs 复制代码
#include<myhead.h>
int main(int argc, const char *argv[])
{
	pid_t pid1 = -1;
	int fd1 = -1;
	int fd2 = -1;
	int num=0;
	ssize_t s;
	if (argc!=3)
	{
		printf("输入格式错误\n");
		return -1;
	}
	pid1 = fork();
	if ((fd1 = open(argv[1],O_RDONLY))==-1)
	{
		printf("源文件打开失败\n");
		return -1;
	}
	printf("源文件打开成功\n");

	off_t len = lseek(fd1,0,SEEK_END);

	lseek(fd1,0,SEEK_SET);

	close(fd1);
	if (pid1>0)
	{
		pid_t pid2 = fork();
		if (pid2>0)
		{
			printf("等待两个子进程的完成\n");	
			waitpid(pid1,NULL,0);
			waitpid(pid2,NULL,0);
			printf("已经成功回收\n");

		}
		else if(pid2==0)
		{
			printf("pid2子进程:%d,拷贝前一半的内容\n",getpid());
			if ((fd1 = open(argv[1],O_RDONLY))==-1)
			{
				printf("源文件打开失败\n");
				return -1;
			}
			printf("源文件打开成功\n");

			if ((fd2 = open(argv[2],O_RDWR|O_CREAT|O_TRUNC))==-1)
			{
				printf("目标文件打开失败\n");
				return -1;

			}
			printf("目标文件打开成功\n");

			char str[128]="";
			while (num<(len/2)&&(s=read(fd1,str,sizeof(str)>(len/2-num)?(len/2-num):sizeof(str)))!=0)
			{
				write(fd2,str,s);
				num=s+num;
				bzero(str,sizeof(str));

			}

			close(fd1);
			close(fd2);
			exit(EXIT_SUCCESS);
		}
	}
	else if (pid1==0)
	{
		num=0;
		printf("子进程:%d,拷贝后一半的内容\n",getpid());
		if ((fd1 = open(argv[1],O_RDONLY))==-1)
		{
			printf("源文件打开失败\n");
			return -1;
		}
		printf("源文件打开成功\n");

		if ((fd2 = open(argv[2],O_WRONLY|O_CREAT|O_APPEND))==-1)
		{
			printf("目标文件打开失败\n");
			return -1;

		}
		printf("目标文件打开成功\n");

		lseek(fd1,len/2,SEEK_SET);
		lseek(fd2,len/2,SEEK_SET);

		char str[128]="";

		while (num<(len-(len/2))&&(s=read(fd1,str,sizeof(str)>(len/2-num)?(len/2-num):sizeof(str)))!=0)
		{
			write(fd2,str,s);
			num=s+num;
			bzero(str,sizeof(str));
		}

		printf("子进程已拷贝\n");
		close(fd1);
		close(fd2);
		exit(EXIT_SUCCESS);
	}

	return 0;
}
相关推荐
手写码匠35 分钟前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力1 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly1 小时前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法
吴可可1231 小时前
SolidWorks草图转三维DWG技巧
算法
tyung2 小时前
Go 手写 Wait-Free SPSC 无界队列:无 CAS、无锁、泛型节点池
数据结构·后端·go
redaijufeng2 小时前
C++雾中风景7:闭包
c++·算法·风景
Chen_harmony2 小时前
一、数据结构概念和复杂度计算
数据结构
小欣加油2 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
尽兴-3 小时前
2.1 向量基础:Embedding、余弦相似度、欧氏距离、向量检索
算法·embedding·欧氏距离·向量检索·余弦相似度
Black蜡笔小新3 小时前
自动化AI算法训练服务器DLTM训推一体工作站赋能多行业智能化升级
人工智能·算法·自动化