我尝试使用kill
功能创建僵尸进程,但它只是杀死了孩子并返回0
。
int main ()
{
pid_t child_pid;
child_pid = fork ();
if (child_pid > 0) {
kill(getpid(),SIGKILL);
}
else {
exit (0);
}
return 0;
}
当我检查流程的状态时,状态列中没有z
。
答案 0 :(得分:3)
这是一个应该创建僵尸的简单配方:
#include <stdio.h>
#include <signal.h>
#include <unistd.h>
int main()
{
int pid = fork();
if(pid == 0) {
/* child */
while(1) pause();
} else {
/* parent */
sleep(1);
kill(pid, SIGKILL);
printf("pid %d should be a zombie\n", pid);
while(1) pause();
}
}
关键是父母 - 即这个程序 - 继续运行,但不对垂死的孩子做wait()
。
僵尸是没有等待的死孩子。如果这个程序等待它死去的孩子,它就会消失而不是僵尸。如果这个程序退出,僵尸孩子将被其他人(可能是init
)继承,这可能会等待,孩子会离开而不是僵尸。
据我所知,僵尸的全部原因是死亡的孩子退出了退出状态,有人可能会想要。但是,在Unix存储退出状态的地方是死亡进程的空壳,以及如何获取死亡孩子的退出状态是等待它。因此,Unix保持僵尸只是为了保持其退出状态,以防父母想要它但尚未调用wait
。
所以它实际上是一种诗意:这里的Unix哲学基本上是不会忽视孩子的死亡。