Posted on 2012-12-02 18:12
鑫龙 阅读(362)
评论(0) 编辑 收藏 引用 所属分类:
linux编程
如果一个进程fork一个子进程,但不要它等待子进程终止,也不希望子进程处于僵死状态直到父进程终止,实现这一要求的技巧是调用fork2次。
下面是实例代码:
#include <stdio.h>
#include <stdlib.h>
#include <sys/wait.h>
int main(void)
{
pid_t pid;
if((pid = fork()) < 0) {
printf("error: fork error.\n");
} else if(pid == 0) {
if((pid = fork()) < 0)
printf("error: fork error.\n");
else if(pid > 0)
exit(0);
/* we are the second child; our parent becomes init as soon as
* our real parent calls exit() in the statement above. Here is
* where we had continue executing , knowing that when we are
* done, init will reap our status.
*/
sleep(2);
printf("second child, parent pid = %d\n", getppid());
exit(0);
}
if(waitpid(pid, NULL, 0) != pid)
printf("error, waitpid error.\n");
exit(0);
}
这里核心思想是,把第二个子进程的父进程换成init进程,因为init进程会立马终止僵死进程。而最开始的父进程也因为直接子进程(第一个进程)终止,不需要阻塞。
第二个子进程调用sleep以保证在打印父进程ID时第一个字进程已终止。在fork之后,父子进程都可以继续执行,并且我们无法预知哪个会限制性。在fork之后,如果不是第二个子进程休眠,那么它可能比其父进程先执行,于是它打印的父进程ID将是创建它的父进程,而不是init进程。