1、fork创建子进程
1.1、为什么要创建子进程
(1)每一个程序的运行都需要一个进程
(2)多进程实现宏观上的并行
1.2、fork的内部原理
(1)进程的分裂生长模式。如果操作系统需要一个新进程来运行一个程序,那么操作系统会用一个现有的进程来复制生成一个新进程。老进程叫父进程,复制生成的新进程叫子进程
(2)fork函数调用一次会返回2次,返回值等于0的就是子进程,而返回值大于0的就是父进程
(3)典型的使用fork的方法:使用fork后然后用if判断返回值,并且返回值大于0时就是父进程,返回值等于0时就是子进程
(4)fork的返回值在子进程中等于0,在父进程中等于本次fork创建的子进程的进程ID
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main(void)
{
pid_t p1 = -1, p2 = -1;
p1 = fork(); //返回2次
if(p1 == 0)
{
//这里是子进程
printf("子进程, pid = %d.\n", getpid());
printf("hello world.\n");
printf("子进程, 父进程ID = %d.\n", getppid());
}
if(p1 > 0)
{
//这里是父进程
printf("父进程, pid = %d.\n", getpid());
printf("父进程, p1 = %d.\n", p1);
}
if(p1 < 0)
{
//这里是fork出错了
}
return 0;
}
/*
执行结果:
父进程,pid=24800.
父进程,pid=24801.
子进程,pid=24801.
hello world.
子进程,父进程ID=24800.
1.3、关于子进程
(1)子进程和父进程的关系:
(2)子进程有自己独立的PCB
(3)子进程被内核同等调度
本文详细解析了 fork 函数在创建子进程中的关键作用,探讨其内部原理,包括进程分裂和复制过程。通过实例展示了如何在 C 语言中使用 fork 实现父子进程交互,并介绍了子进程与父进程的关系、独立性及调度。

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



