Linux编程基础之创建父子孙进程(A->B->C)
操作系统:Fedora要求:编写一个程序,实现下图所示的进程之间的关系,其中箭头的方向表明它们之间的生成关系,即A是祖先进程,C是孙子进程。
·
前言
操作系统: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());
}
更多推荐
已为社区贡献1条内容
所有评论(0)