Fork的基本知识:
一个进程,包括代码、数据和分配给进程的资源。fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事,但如果初始参数或者传入的变量不同,两个进程也可以做不同的事。
一个进程调用fork()函数后,系统先给新的进程分配资源,例如存储数据和代码的空间。然后把原来的进程的所有值都复制到新的新进程中,只有少数值与原来的进程的值不同。相当于克隆了一个自己。
fork函数有趣的地方在于它只被调用一次,却会返回两次:一次是在调用进程(父进程)中,,一次是在新创建的子进程中。在父进程中,fork返回子进程的pid,在子进程中返回0;注:子进程的pid总是非零的,故可以通过返回值的方法来明确程序是在父进程还是子进程中执行。
每个进程都有一个唯一的正数(非零)进程ID(PID)。getpid函数返回调用进程的PID,getppid函数返回它的父进程的PID。
进程图,进程图是刻画程序语句偏序的一种简单的前趋图。每个顶点a对应一条程序语句的执行。有向边a------->b表示语句a发生在语句b之前。边上可以标记出一些信息,例如一个变量的当前值。
下面通过一些程序由浅入深的理解fork函数的机理:
下面所有函数的头文件:(之后就不一一再指出来)
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <signal.h>
#typedf pi
1简单fork基础
void fork0()
{
int x = 1;
pid_t pid = fork();
if (pid == 0) {
printf("Child has x = %d\n", ++x);
}
else {
printf("Parent has x = %d\n", --x);
}
printf("Bye from process %d with x = %d\n", getpid(), x);
}
运行结果:
这里我们可以看到调用fork后,返回pid。用getpid函数返回进程PID.当(pid!=0)时执行代码后x=0,父进程PID:2263。当(pid=0)时执行代码后x=2,子进程PID:2264.
2:一次调用两次返回
void fork2()
{
printf("L0\n"