fork()后 父子进程变量地址一致
2013-03-01 12:46
316 查看
来源网络:
View Code
输出:
打印出来的 x 的地址是虚拟地址而不是物理地址(总线地址)。
子进程“继承”父进程的变量,其地址总是一样的,因为在fork时整个虚拟地址空间被复制,但是虚拟地址空间所对应的物理内存却没有复制(这个时候父子进
程中变量 x对应的虚拟地址和物理地址都相同)。等到虚拟地址空间被写时,对应的物理内存空间被复制(这个时候父子进程中变量 i
对应的虚拟地址还是相同的,但是物理地址不同),这就是"写时复制"。
那个一样的地址是线性地址,每个进程的相同的线性地址都可以映射到不同的物理地址上。在fork的时候,子进程从父进程了copy了task_struct结构,其中task_struct里的mm就是线性地址的使用情况,mm也会被copy给子进程,所以在fork之前声明的变量,在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后在父进程和子进程里的线性地址是一样的。
相关文章推荐
- fork()后,父子进程变量地址相同?
- 关于fork函数生成父子进程变量虚拟地址
- fork()后父子进程间的变量共享情况
- Linux中fork()函数详解 父子进程变量的关系
- fork 父子进程变量之间的关系
- linux进程系列(3)父子进程变量虚拟内存地址相同但变量值不同的问题
- fork()例程--父子进程,对线性地址的说明(3)
- fork之后父子进程虚拟地址(逻辑地址)相同的问题
- fork()父子进程变量之间的关系与信号的响应
- 父子进程变量的地址一样,但值不一样
- 20170907_关于 fork函数和父子进程的理解
- fork、execl , waitpid实现父子进程管道间通讯
- 关父子进程关系fork()
- fork后父子进程共享资源
- Linux下父子进程的全局变量
- fork后父子进程文件描述问题
- 问题:子进程父进程哪个先执行:【转】关于 fork 和父子进程的理解 + 【转】
- fork()+pipe() --> 父子进程间通过管道通信
- [置顶] Linux高编之进程--------fork函数的同步与异步(兄弟子进程和父子孙进程示列)
- 创建子进程时变量的地址与父进程一样而数值不一样的问题