Linux--进程复制

进程复制 – fork方法

pid_t fork(void);
在这里插入图片描述
程序执行结果:
在这里插入图片描述
fork方法调用成功后,就会有两个进程储存在,调用fork进程为父进程,新复制的进程为子进程
fork有两次返回,父进程中返回子进程pid,子进程中返回0

fork之前代码只有父进程会执行,fork之后父子进程分别执行,子进程只执行fork之后的代码
在上述代码中可以将想父进程执行的代码块放在else中,想子进程执行的代码块放在if块中
fork之后,父子进程并发执行,先后并不依赖代码的先后顺序


思考1:
在这里插入图片描述
程序分析:
在这里插入图片描述
所以输出就是三A三B
在这里插入图片描述

思考2:
在这里插入图片描述
分析:在第一个fork之后,返回两个值,一个pid号,一个是0,子进程返回值为0,分支直接跳入else,输出一个B;父进程返回值为pid,所以等待第二个参数,第二次fork返回一个0,一个pid,第一次的pid&&0,第二次子进程的分支跳入else,输出B,第二次的父进程和第一次的父进程pid&&pid,输出A,所以结果是两个B一个A,同样的方法分析当条件变为”fork() || fork()“的结果。在这里插入图片描述
提前结束子进程直接在分支中exit(0)即可


fork之后,父子进程数据上的关系:

进程
.data .bss 父子进程不共享
.heap 父子进程不共享
.stack 父子进程不共享
数据的逻辑地址相同,实际地址不同(写时拷贝之后)

fork之后父子进程共享数据段,栈和堆,而且内核将这些区域的权限修改为只读
如果父、子进程任意一个试图修改空间上的数据,则操作系统会将修改的数据所在的页复制一份(写时拷贝技术)

.heap数据研究问题:(Linux中)
1.堆区物理空间什么时候分配
malloc只是在虚拟地址上分配内存,并没有分配真实的物理地址空间,只有在使用时才会分配物理空间

2.一个进程能够申请的堆空间由什么限制
如果交换分区没有开启,malloc申请的大小由内存限制,开启交换分区,则由内存大小、交换分区、虚拟内存共同限制

3.验证写时拷贝技术
fork方法执行成功并没有立即将空间复制,而是在修改空间数据时,才会一点点分配

父子进程对于fork之前打开的文件描述符是否共享
是共享的,如果同时访问,则可能会出问题
fork之后的拷贝是浅拷贝,指针拷贝是拷贝指针,但是指向的节点不会拷贝

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值