首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >进程fork函数

进程fork函数

作者头像
程序员小王
发布2018-04-13 11:10:22
1.3K0
发布2018-04-13 11:10:22
举报
文章被收录于专栏:架构说架构说架构说
验证1 fork会重新拷贝父进程的一份资源

例如 环境变量 公共变量

代码地址: https://code.csdn.net/snippets/1697496.git

int glob_int = 1; /* on .data section */ int* ptr= new int[3];

[wang@localhost fork]$ ./a.out ptr index=0 value= 1 ptr index=1 value= 2 ptr index=2 value= 0 child pid = 25994, glob_int = 2 ptr=0x1c26010, ptr index=0 value= 3 ptr index=1 value= 4 ptr index=2 value= 0 parent pid = 25993, glob_int = 1 ptr=0x1c26010

Q1 为什么父子进程打印的ptr地址是一样的

A1: 现象如下父进程malloc的指针指向0x12345678, fork 后,子进程中的指针也是指向0x12345678,但是这两个地址都是虚拟内存地址 (virtual memory),经过内存地址转换后所对应的 物理地址是不一样的。

所以两个进程中的这两个地址相互之间没有任何关系

(注1:在理解时,你可以认为fork后,这两个相同的虚拟地址指向的是不同的物理地址,这样方便理解父子进程之间的独立性) (注2:但实际上,linux为了提高 fork 的效率,采用了 copy-on-write 技术,fork后,这两个虚拟地址实际上指向相同的物理地址(内存页),只有任何一个进程试图修改这个虚拟地址里的内容前,两个虚拟地址才会指向不同的物理地址(新的物理地址的内容从原物理地址中复制得到))

虚拟地址里映射到真实的物理地址

验证2 共享数据块

fork 之后 父子进程之间什么样的数据是相同的?

  • fork之后父子进程共享文件表的同一项
  • A B进程操作外界资源 虽然是2个入口但是同一份数据 一方修改会影响另外一方 例如 为了提高性能、降低数据库连接消耗,openboss采用DBPool来管理数据库连接且DBPool为全局变量,所以当子进程退出时会调用DBPool的析构函数,DBPool的析构函数会执行断开数据库连接的操作
验证3 共享内存是进程本身的资源吗?

不是 共享内存有持续性: 随内核, 即进程重启共享内存中数据不会丢失 本身不具备协作能力 需要互斥锁 信号量等完成

http://blog.csdn.net/xy010902100449/article/details/44851453

http://blog.csdn.net/cywosp/article/details/27316803

http://blog.csdn.net/ordeder/article/details/21716639 http://blog.csdn.net/sunmenggmail/article/details/7565337

http://www.cnblogs.com/zhaoyl/p/3695517.html http://blog.csdn.net/liuhongxiangm/article/details/8308291

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2016-05-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Offer多多 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 验证1 fork会重新拷贝父进程的一份资源
  • 验证2 共享数据块
  • 验证3 共享内存是进程本身的资源吗?
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档