fork()函数:
创建一个子进程(拷贝父进程的PCB、页表,然后修改PCB中的部分数据);
声明:
#include <unistd.h>
pid_t fork(void);
返回值: 原来进程返回新进程PID,新进程返回0;出错返回 -1 ;
fork函数测试(fork之后父子进程互为独立进程,操作系统决定谁先执行):

运行结果:

父子进程关系:
- 子进程的PID是独一无二的不属于任何进程组;
- 子进程的PPID为父进程PID;
- 子进程将资源利用率(getrusage(2))和CPU时间计数器(times(2))重置为零,将等待信号(sinpending(2))初始化为空;
- 子进程没有继承父进程的内存锁(memory locks) (mlock( 2,mlockall(2) )、记录锁(record locks)(fcntl(2))、计时器(timers) (sertirimer(2),alarm(2),timer_create(2));
写时拷贝技术:
fork函数之后,子进程会拷贝父进程的PCB结构,然后对PCB里面数据做修改。父进程的页表直接拷贝给子进程。父子进程文件描述符共享,全局、局部变量、堆区数据数据不共享。
本文详细解析了fork()函数的工作原理,包括创建子进程的过程、父子进程的关系、资源分配及写时拷贝技术。了解fork()如何实现进程复制及其对操作系统资源的影响。
652

被折叠的 条评论
为什么被折叠?



