使用fork时如何映射内存?

buc*_*h11 5 c linux fork address-space

我是"fork()"的新手,我随处读到,当调用fork()时,启动当前(调用)进程的精确副本.现在,当我运行以下代码时,应该有两个不同的进程,有两个不同的分配给其变量和函数的内存位置.

#include<stdio.h>
int i=10;
int pid;
 int main(){
  if((pid=fork())==0){
    i++;//somewhere I read that separate memory space for child is created when write is needed
    printf("parent address= %p\n",&i);// this should return the address from parent's memory space
  }else{
    i++;
    i++;
    printf("child address= %p\n",&i);// this should return the address of child's memory space 
  }
  wait(0);
  return(0);
 }
Run Code Online (Sandbox Code Playgroud)
Why The output looks like:: 
child address::804a01c 
parent address::804a01c

为什么父母和孩子的地址都是一样的?

Fre*_*Foo 8

将两个不同的存储位置分配给它们的变量和功能.

不; Linux实现虚拟内存,这意味着每个进程都有自己的完整地址空间.因此,在a之后fork,两个进程都会看到内存对象副本的相同地址.

(顺便说一下:VM还会导致代码在物理内存中的进程之间共享,并且所有数据都只能在写入时复制.)

  • 事实上,"旁白"非常重要:在生成子进程时没有真正复制任何内容.这将是一个巨大的性能损失,因为在Unix上经常发生分叉(几乎每次你产生一个新进程).精确的机制依赖于"页面错误".如果您有兴趣,可能需要阅读它们. (4认同)
  • 只有内核知道哪个物理地址对应于给定的虚拟地址.用户模式程序无法轻易检测到它在具有MMU的系统上运行. (2认同)