csapp笔记----fork函数的理解

Fork的基本知识
一个进程,包括代码、数据和分配给进程的资源。fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事,但如果初始参数或者传入的变量不同,两个进程也可以做不同的事。
一个进程调用fork()函数后,系统先给新的进程分配资源,例如存储数据和代码的空间。然后把原来的进程的所有值都复制到新的新进程中,只有少数值与原来的进程的值不同。相当于克隆了一个自己。
fork函数有趣的地方在于它只被调用一次,却会返回两次:一次是在调用进程(父进程)中,,一次是在新创建的子进程中。在父进程中,fork返回子进程的pid,在子进程中返回0;注:子进程的pid总是非零的,故可以通过返回值的方法来明确程序是在父进程还是子进程中执行。
每个进程都有一个唯一的正数(非零)进程ID(PID)。getpid函数返回调用进程的PID,getppid函数返回它的父进程的PID。
进程图,进程图是刻画程序语句偏序的一种简单的前趋图。每个顶点a对应一条程序语句的执行。有向边a------->b表示语句a发生在语句b之前。边上可以标记出一些信息,例如一个变量的当前值。
下面通过一些程序由浅入深的理解fork函数的机理:
下面所有函数的头文件:(之后就不一一再指出来)

#include 
#include 
#include 
#include 
#include  
#include 
#typedf pi

1:

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);
}

运行结果:
csapp笔记----fork函数的理解_第1张图片
这里我们可以看到调用fork后,返回pid。用getpid函数返回进程PID.当(pid!=0)时执行代码后x=0,父进程PID:2263。当(pid=0)时执行代码后x=2,子进程PID:2264.
2:

void fork2()
{
    printf("L0\n");
    fork();
    printf("L1\n");    
    fork();
    printf("Bye\n");
}

运行结果:
csapp笔记----fork函数的理解_第2张图片
进程图:

你可能感兴趣的:(深入理解计算机系统)