fork子进程

for子进程

fork之后exec之前两个进程使用的是相同的物理空间,也就是相同的内存区,子进程的代码段、数据段、堆栈段都是指向父进程的物理空间的,也就是说,虽然两者的虚拟空间不同,但是对应的物理空间是同一个。
只有进程空间的隔断的内容需要发生变化时,才会将父进程的内容复制一份给子进程。

fork复制了什么?
子进程创建虚拟空间结构,它们用来复制父进程的虚拟结构。但是不为这些段分配物理内存,它们共享父进程的物理空间,但是当子进程有更改相应段的行为发生时,再为子进程相应的段分配物理空间。fork时子进程获得父进程数据空间、堆和栈的复制,所以变量的地址(当然是虚拟地址)也是一样的。堆栈都是指向父进程的物理空间 (两者的虚拟空间不同,但其对应的物理空间是同一个)
fork的实际开销就是复制父进程的页表给子进程创建的唯一的进程描述符。

完全复制父进程的栈空间,也复制了页表,但没有复制物理页面,所以这时虚拟地址相同,物理地址也相同,但是会把父子共享的页面标记为“只读”(类似mmap的private的方式),如果父子进程一直对这个页面是同一个页面,知道其中任何一个进程要对共享的页面“写操作”,这时内核会复制一个物理页面给这个进程使用,同时修改页表。而把原来的只读页面标记为“可写”,留给另外一个进程使用。

代码、数据:代码是共享的,不可更改;数据等需要变动时发生写时拷贝;

进程控制块:凡是进程都会有,子进程的PCB以父进程为模板

地址空间:子进程也会有一份,和父进程有一样

页表:子进程也会有一份,数据发生变化时,由于发生了写时拷贝,映射到物理内存的地址会变化

struct files:子进程也可能会打开文件,为了管理文件就需要 fd_array[ ],内容和父进程一样

fork之后子进程到底复制了父进程什么?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值