COW(copy on write)探析

COW copy on write 写时复制。
应用背景。
传统的fork函数,当我们调用fork函数创建子进程。子进程会复制父进程的用户空间的所有内容。(这里容我啰嗦一下,CUP根据虚拟地址通过MMU转换成物理地址,访问物理地址上的内容,将内容存到内存上,再将内容在通过虚拟地址写到物理地址,这就是复制所消耗的资源。)但是如果我们fork的子进程,要进行exec,那么我们之前复制的数据,将全部作废,毫无意义,所以linux引入了COW,在没有写数据前,父子进程以只读的方式共享同一块物理内存,但是有各自的虚拟内存空间,但是不同的虚拟内存空间是被映射到同一块物理内存中,在只有当在写的时候,进程才会将数据复制出来。这样就可以延时甚至免去数据的复制。

在这里再说一下进程的空间。
进程空间大致分成5块
1. 堆
2. 栈
3. BBS
4. 数据段
5. 代码段
当我们调用fork时,父进程中这5块都有对应的物理内存。进程也有自己的虚拟地址各自指向物理地址。fork后用COW优化后的子进程,也是由自己的虚拟地址空间,同样指向父进程的物理地址。当要写入时,子进程再各自要写的段开辟一块物理地址让虚拟地址指向,并将父进程的内容拷贝出来,进行修改。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值