fork()后 父子进程变量地址一致

来源网络:

View Code
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <iostream>

int main()
{
    int x = 5;

    pid_t pid = fork (); 

    if (0 == pid)
    {   
        std::cout << "pid = " << pid << std::endl;
        x = 6;
        std::cout << "x = " << x << " &x = " << &x << std::endl;
    }   
    else if (pid > 0)
    {   
        std::cout << "pid = " << pid << std::endl;
        x = 7;
        std::cout << "x = " << x << " &x = " << &x << std::endl;
    }   
    else 
    {   
        std::cerr << "Error" << std::endl;
    }   
    exit (0);
}

输出:

 

打印出来的 x 的地址是虚拟地址而不是物理地址(总线地址)。
子进程“继承”父进程的变量,其地址总是一样的,因为在fork时整个虚拟地址空间被复制,但是虚拟地址空间所对应的物理内存却没有复制(这个时候父子进 程中变量 x对应的虚拟地址和物理地址都相同)。等到虚拟地址空间被写时,对应的物理内存空间被复制(这个时候父子进程中变量 i 对应的虚拟地址还是相同的,但是物理地址不同),这就是"写时复制"。

那个一样的地址是线性地址,每个进程的相同的线性地址都可以映射到不同的物理地址上。在fork的时候,子进程从父进程了copy了task_struct结构,其中task_struct里的mm就是线性地址的使用情况,mm也会被copy给子进程,所以在fork之前声明的变量,在fork后在父进程和子进程里的线性地址是一样的。

转载于:https://www.cnblogs.com/lc-cnblong/archive/2013/03/01/2938474.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值