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

本文详细介绍了Unix系统调用fork()的工作原理,包括进程的复制、并发执行、wait和waitpid函数的使用,以及如何处理子进程的结束。通过一系列实例,深入探讨了fork在并发编程中的应用,包括死循环、孤儿进程和僵死进程的处理,以及标准I/O缓冲区的影响。最后,文章还提供了几个课后习题的解决方案,展示了exit()和return在子进程中的区别。
摘要由CSDN通过智能技术生成

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"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值