在UNIX fork之后指向动态分配内存的指针会发生什么?

Dmi*_*tri 9 c unix fork

有人请说明fork()之后指针会发生什么.

据我了解,指向堆栈上任何内容或静态分配的指针都与堆栈/数据段寄存器相关,因此在fork期间准确复制它们是可以的.

但是,如果我在分叉前使用malloc()会发生什么?例如:

void* p = malloc(64);
// put something in *p;
fork();

// what happens to p and the memory i allocated here?
Run Code Online (Sandbox Code Playgroud)

我想到的可能性:

  1. *p被复制到堆的其他部分,p被更新以反映新复制的位置.

  2. p仍然指向原始.如果有孩子自由奔跑(p); 父母可能无法访问它.

  3. p仍指向原始数据,但子进程无权访问/管理内存.

哪些,如果有的话,是正确的?

小智 13

分叉时,子进程成为其父进程的副本.这包括任何动态分配的内存.所以内存将被复制.指针地址将保持不变(复制不会更改数据,还记得?),这是通过虚拟寻址实现的.不要忘记调用free父进程和子进程.