子进程复制了父进程的什么

这里涉及到物理地址和逻辑地址(或称虚拟地址)的概念

  • 逻辑地址:CPU所生成的地址
  • 物理地址:内存单元所看到的地址

从逻辑地址到物理地址的映射称为地址重定向

CPU产生的逻辑地址被分为

  • p (页号) 它包含每个页在物理内存中的基址
  • d (页偏移)用来作为页表的索引

用户只生成逻辑地址,且认为进程的地址空间为0到max。物理地址范围从R+0到R+max,R为基地址

每个进程都有自己的虚拟地址空间,不同进程的相同的虚拟地址显然可以对应不同的物理地址

在fork之后exec之前两个进程用的是相同的物理空间,子进程的代码段、数据段、堆栈都是指向父进程的物理空间。当父子进程中有更改相应段的行为发生时,再为子进程相应的段分配物理空间。而如果是因为exec,子进程的代码段也会分配单独的物理空间

一个进程一旦调用exec类函数,它本身就”死亡”了,系统把代码段替换成新的程序的代码,废弃原有的数据段和堆栈段,并为新程序分配新的数据段与堆栈段,唯一留下的,就是进程号,也就是说,对系统而言,还是同一个进程,不过已经是另一个程序了

子进程复制了父进程的行缓冲

printf("one");
fork();
printf("two");
posted @ 2015-08-07 13:19  thomas_blog  阅读(208)  评论(0编辑  收藏  举报