- 进程的正式引入
1)什么是进程
动态过程而不是静态实物
进程就是程序的一次运行过程,一个静态的可执行程序a.out 的一次运行过程(./a.out去运行到结束)就是一个进程。
进程控制块PCB(process control block),内核中专门用来 管理一个进程的数据结构。 - 进程ID
getpid、getppid、getuid、geteuid、getgid、getegid - 进程调度原理
操作系统同时运行多个进程
宏观上的并行和微观上的串行
实际上现代操作系统最小的调度单元是线程而不是进程 - fork创建子进程
为什么要创建子进程
每一次程序的运行都需要一个进程
多进程实现宏观上的并行 - fork的内部原理
1)进程的分裂生长模式。如果操作系统需要一个新进程来运行 一个程序,那么操作系统会用一个现有的进程来复制生成一个新 进程。老进程叫父进程,复制生成的新进程叫子进程。
2)fork的演示
#include<stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main(void)
{
pid_t p1 = -1;
p1 = fork(); // 返回两次
if (p1 == 0)
{
// 这里一定时子进程
printf("子进程, pid = %d.\n", getpid()); // 返回本进程ID
}
if (p1 > 0)
{
// 这里一定时父进程
printf("父进程, pid = %d.\n", getpid()); // 返回本进程ID
printf("父进程, p1 = %d.\n", p1); // 这里的p1和子进程的getpid的值是相等的
}
if (p1 < 0)
{
// fork 出错了
}
// 在这里所做的操作
// printf("hello world, pid = %d.\n", getpid());
return 0;
}
3 ) fork函数调用一次会返回2次,返回值等于0的就是子进程,而返回值大于0的就是父进程。
4 ) 典型的使用fork的方法:使用fork后然后用if判断返回值,并且返回值大于0时就是父进程,等于0时就是子进程。
5 ) fork的返回值在子进程中等于0,在父进程中等于本次fork创建的子进程的进程ID。
来源: 朱老师网络大课堂