13.进程-fork函数的原理和进程空间

本文讨论的仅仅限于Linux 32位系统

进程空间

进程空间,指的是进程的虚拟地址空间

每个进程都有自己的4GB 虚拟地址空间,每个进程的进程虚拟地址空间是相互隔离的,互不影响;

虚拟地址到物理地址的映射

每个进程都保留着自己的地址空间到物理地址的映射表;

这个页(地址空间)到页框(物理内存空间)的映射表就叫页表;

fork函数的返回值

前一节讲了 fork 就是将进程的地址空间完完全全的复制了一份(不是100%复制,除少数几个地方外),实际在复制完后,操作系统会悄悄的修改复制出来的进程空间里的 fork 函数的返回值,把它改成 0(准确的说不是改,而是根本就没有复制原来的值,直接把它赋值为 0);

这也就是子进程 fork 函数返回了 0 的原因;

写时复制技术-Copy On Write(COW) 

当你的进程与其他的进程使用了内容一样的页框,MMU会把你的进程和其他的进程指向同一块页框;

读取内容的时候,你和别人共享同一个页框;即,读时共享;

当你要进行修改的时候,MMU才会复制出新的一块页框给你,即写时复制;

猜你喜欢

转载自blog.csdn.net/regemc/article/details/80862583
今日推荐