前言

操作系统:Fedora
要求:编写一个程序,实现下图所示的进程之间的关系,其中箭头的方向表明它们之间的生成关系,即A是祖先进程,C是孙子进程。
本文为作者班级作业,同班同学参考借鉴的话,别直接拿本文的截图交差啊 : )

代码

vartest1.c 文件代码如下

#include <sys/types.h>
#include <unistd.h>
#include <stdio.h>
int main(){
        int pid;
        printf("I am A,mypid=%d\n",getpid());
        pid=fork();//创建子进程B
        if(pid==0){
                printf("I am B,mypid=%d\n",getpid());
                int pid1=fork();//创建孙子进程C
                if(pid1==0){
                        printf("I am C,mypid=%d\n",getpid());
                }
        }
       // printf("my pid is %d\n",getpid());
        return 0;
}

执行结果

在这里插入图片描述

代码解释

if(pid==0){
......
}

fork系统调用与其他调用的区别在于它会返回两次:一次返回到执行fork操作的父进程,一次返回到子进程,父子进程通过不同的返回值进行区分。它在父进程中的返回值为新创建的子进程的PID号,而子进程的返回值为0。默认情况下,父子进程具有相同的代码,执行完成后,父子进程均从fork()代码后面的语句开始执行。
对于子进程B,pid=0,执行该代码块,对于父进程A,pid>0,不执行该代码块

下面的代码和上面同理

if(pid1==0){
	printf("I am C,mypid=%d\n",getpid());
}
Logo

更多推荐