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


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

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

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

    CPU产生的逻辑地址被分为

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

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

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

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

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

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

    printf("one");
    fork();
    printf("two");
  • 相关阅读:
    re模块
    collections模块
    hashlib模块
    序列号模块
    random模块
    sys模块
    OS模块
    工厂模式
    Go语言之直接选择排序
    Go语言之直接插入排序
  • 原文地址:https://www.cnblogs.com/zhangxuechao/p/11709923.html
Copyright © 2020-2023  润新知