CopyOnWrite 机制是如何实现的

2019-01-30  本文已影响32人  顽强的猫尾草

当父进程 fork() 产生一个子进程时,会把父进程的代码段、数据段等拷贝给子进程,这里边有一个写时拷贝原则(CopyOnWrite),这个动作并不是马上执行的,要等到子进程去修改内存里面的变量时候,才会进行拷贝。

拷贝的机制并不是想象的那么简单,拷贝的时候只是拷贝子进程所需要的页,每个进程 OS 都会进行分页管理,虚拟的内存空间 2^32 远远大于物理内存空间,然后把物理内存分成一页一页的形式,如果这个变量放在第一页,就只会进行第一页的拷贝,这个时候要操作第二页的数据时候,这个时候操作系统会进行一个软中断,也就是缺页中断,之后再把父进程中的数据拷贝到子进程中,如果父进程没有产生缺页中断之前,父进程对变量进行了修改,操作系统也会维护进程之间的状态,在父进程修改数据之前,把页该拷贝的拷贝。

如果多个进程要读取他们自己那部分资源的副本,那么赋复制是不必要的,每个进程只要保存一个指向这个资源的指针就够了,如果一个进程要修改自己的那部分资源的副本,那么就会复制那份资源,这就是 CopyOnWrite 的含义。

上一篇下一篇

猜你喜欢

热点阅读