嵌入式学习-IO进程线程-Day4

嵌入式学习-IO进程线程-Day4

一、思维导图

在这里插入图片描述

二、模拟面试

1.标准IO和文件IO的区别

标准IO:依赖于库函数(程序提供的函数),该函数内封装了缓冲区,调用该函数时先将操作的数据放入缓冲区,待刷新时机到了后,调用系统调用函数将数据统一刷入到内核空间,效率较高。是基于文件指针的操作

文件IO:依赖于系统调用(室内和提供的函数),每次进行该调用时都会执行一次系统调用,效率较低。是基于文件描述符(整形数据)的操作。

标准IO=文件IO+缓冲区

2.创建进程中的写时拷贝技术

子进程在刚刚创建出来时,父子内存共用同一物理内存。当父进程或子进程对数据有写操作时,则会为子进程分配物理映射内存。

三、作业

1.创建出三个进程完成两个文件之间拷贝工作,子进程1拷贝前一半内容,子进程2拷贝后一半内容,父进程回收子进程的资源

#include <myhead.h>
//使用三个进程完成两个文件的拷贝工作
//两个子进程分别拷贝文件的上下两部分
//父进程回收资源

int main(int argc, const char *argv[])
{
	//判断外部传参
	if(argc!=3)
	{
		printf("input file error\n");
		printf("usage: ./a.out inputfile outfile\n");
		return -1;
	}

	int srcfd=-1,dstfd=-1,fd=-1;
	char buf[10]="";

	//计算文件中间的位置
	if((fd=open(argv[1],O_RDONLY))==-1)
	{
		perror("open file error");
		return -1;
	}
	int pos=lseek(srcfd,0,SEEK_END)/2;

	//创建第一个子进程
	pid_t pid1=-1;
	pid1=fork();

	if(pid1 == 0)  
	{
		printf("我是老大,我来拷贝上半部分\n");
		//打开源文件
		if((srcfd=open(argv[1],O_RDONLY))==-1)
		{
			perror("1 open srcfile error");
			return -1;
		}
		//打开目标文件
		if((dstfd=open(argv[2],O_WRONLY|O_CREAT|O_TRUNC,0664))==-1)
		{
			perror("1 open dstfile error");
			return -1;
		}
		//拷贝
		int count=0;
		while(1)
		{
			memset(buf,0,sizeof(buf));
			int res=read(srcfd,buf,sizeof(buf));
			write(dstfd,buf,res);
			count+=res;
			if(count>=pos)
			{
				break;
			}
		}
			//关闭
			close(srcfd);close(dstfd);
			printf("上半部分拷贝完成\n");
			exit(EXIT_SUCCESS);
		
	}else if(pid1 > 0)
	{
		//创建第二个子进程
		pid_t pid2=fork();
		if(pid2 == 0)
		{
			printf("我是老二,我来拷贝下半部分\n");
			//打开源文件
			if((srcfd=open(argv[1],O_RDONLY))==-1)
			{
				perror("2 open srcfile error");
				return -1;
			}
			//打开目标文件
			if((dstfd=open(argv[2],O_WRONLY|O_CREAT|O_TRUNC,0664))==-1)
			{
				perror("2 open dstfile error");
				return -1;
			}
			//偏移光标
			lseek(srcfd,pos,SEEK_SET);

			//拷贝
			while(1)
			{
				memset(buf,0,sizeof(buf));
				int res=read(srcfd,buf,sizeof(buf));
				write(dstfd,buf,res);
				if(res==0)
					break;
			}
			//关闭
			close(srcfd);close(dstfd);
			printf("下半部分拷贝完成\n");
			sleep(3);
			exit(EXIT_SUCCESS);
		}else if(pid2 > 0)
		{
			printf("我是父进程\n");
			sleep(5);
			wait(NULL);
			printf("回收一个子进程\n");
			wait(NULL);
			printf("回收一个子进程\n");
		}else
		{
			perror("fork2 error");
			return -1;
		}
	}else
	{
		perror("fork1 error");
		return -1;
	}
	return 0;
}

运行结果
在这里插入图片描述

  • 11
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值