Q:为什么不是子进程中返回父进程pid,父进程中返回0呢?
那是因为一个父进程有很多子进程,如果不返回其特定子进程的pid,之后需要调用其子进程时就找不到这个子进程了;而一个子进程只有一个父进程,如果要看其父进程的pid只需要通过调用getppid()函数即可。举一个简单的例子 代码如下图
代码实现过程分析
在Linux gcc环境下的执行结果为
由此延伸几个fork函数的应用
例一:
void main() { int i = 0; for(;i<2;i++) { if(fork()) printf("A\n"); else printf("B\n"); } }执行一次结果:AABBAB 执行两次结果:AABABB … … 执行n次结果:总是包含3个A,3个B
代码执行过程分析
注:fork函数调用之后,哪个进程优先执行,与操作系统的进程调度算法和当前计算机环境有关,打印出来的先后是不定的。例二:
void main() { if(fork() || fork()) printf("A\n"); else printf("B\n"); }执行结果:AAB
代码执行过程分析
注: 1||1 = 1;1 || 0 = 1;0 || 1 = 1;0 || 0 = 0 当“||”前为1时,则不用判断后面一个;如果“||”之前为0,继续执行后面表达式。例三:
void main() { int i = 0; for(;i<2;i++) { if(fork()) printf("A"); else printf("B"); } }执行一次结果:AAABBABB … … 执行n次结果:总是包含4个A,4个B
代码执行过程分析
注:当printf中没有"\n"时,缓冲区无法刷新,每个PCB的缓冲区都将保留函数返回的结果,当i = 1时,所产生的子进程将缓冲区也复制过来,因此,例三程序相对于例一就多出了一个A和一个B。最后,在例三函数显示父进程的执行过程中会出现孤儿进程,所谓孤儿进程就是说父进程已经结束,而子进程未结束,其子进程就成为了孤儿进程。
pid_t getpid() //得到pid ppid_t getppid() //得到ppid解决孤儿进程的方法:让父进程在子进程结束之前进入睡眠状态,即父进程在子进程结束之前不会结束。
# define a 5 sleep(a--);