子进程复制了父进程的什么
这里涉及到物理地址和逻辑地址(或称虚拟地址)的概念
- 逻辑地址:CPU所生成的地址
- 物理地址:内存单元所看到的地址
从逻辑地址到物理地址的映射称为地址重定向
CPU产生的逻辑地址被分为
- p (页号) 它包含每个页在物理内存中的基址
- d (页偏移)用来作为页表的索引
用户只生成逻辑地址,且认为进程的地址空间为0到max。物理地址范围从R+0到R+max,R为基地址
每个进程都有自己的虚拟地址空间,不同进程的相同的虚拟地址显然可以对应不同的物理地址
在fork之后exec之前两个进程用的是相同的物理空间,子进程的代码段、数据段、堆栈都是指向父进程的物理空间。当父子进程中有更改相应段的行为发生时,再为子进程相应的段分配物理空间。而如果是因为exec,子进程的代码段也会分配单独的物理空间
一个进程一旦调用exec类函数,它本身就”死亡”了,系统把代码段替换成新的程序的代码,废弃原有的数据段和堆栈段,并为新程序分配新的数据段与堆栈段,唯一留下的,就是进程号,也就是说,对系统而言,还是同一个进程,不过已经是另一个程序了
子进程复制了父进程的行缓冲
printf("one");
fork();
printf("two");