linux系统调用函数心得:fork()

本文介绍了在Linux环境下使用fork()创建进程的过程,详细阐述了从父进程调用fork()到子进程生成后的变量继承与独立,以及写时复制机制。通过对进程创建和结束情况的探讨,揭示了Linux调度的随机性和资源管理策略。
摘要由CSDN通过智能技术生成

本文适用范围

1.了解fork()的主要功能
2.已阅读man fork
3.尚未进行深入探究
4.在运用过程中对一些细节产生疑惑

今天希望能编写自己的shell程序,练习并探索fork()的用法。
下面一些心得体会。

我把这些心得体会按照进程创建-destroy 的方式描述。

所有非特别标注的心得都是原创

我认为是这样

一.父进程P1调用fork()

二.子进程P2生成,由new - ready

其间,各种变量继承和初始化。此时,P2的所有变量和P1公用。除了pid,pid是不同物理地址(相同逻辑地址)的两个变量。

三.父进程和子进程开始执行

父子进程在等待queue里的先后顺序比较随机,依赖操作系统的短程调度 调度算法。
如果执行时子进程变量值改变,则该变量不再与P1共享地址,自动复制,并改变值。
此时,该变量虚拟地址与P1的相同,物理地址不同。
这是linux写时复制机制。
我猜呢,是因为资源有限而设定的。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值