fork系统调用

本文详细解析了fork系统调用的过程,包括进程创建时的PCB分配、父子进程的返回值、内容是否完全一致以及内存分配策略。阐述了fork如何复制父进程,并在写时拷贝策略下减少不必要的内存复制。同时,提到了文件描述符和工作目录在子进程中的继承关系。
摘要由CSDN通过智能技术生成

一、进程的创建过程(fork底层调用)

  fork是复制进程,那么首先就要搞清楚进程是什么?进程是一个正在运行的程序,是系统分配资源的基本单位。系统管理进程是通过对进程控制块(PCB)的管理完成的。每个进程的产生分两步,第一步:分配PCB,第二步:准备进程实体,如分配内存空间等。目前fork底层是通过do_fork方法传入的不同参数来实现的。首先为进程分配一个唯一标识符pid,这一步失败就会退出复制。pid能表示的范围也就决定着系统理论上最多能运行多少个进程。接下来分配PCB,并继承父进程中的PCB的值,只是将特有的信息改过来。用父进程的内核栈复制给子进程,但将eax寄存器的值强制为0,这也就是问为什么父子进程为什么沿着同一位置开始执行以及子进程的返回值为什么是0,接下来根据传入do_fork的参数复制进程实体,复制的时候有写时拷贝

二、fork以后,父子进程分别返回什么?

  每次fork之后都返回两次,在父进程中返回的是子进程的PID,在子进程中则返回0。后续代码根据返回值判断是子进程还是父进程

三、fork之后父子进程中的内容是完全一样的吗?

 当然

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值