我在debian-linux上运行我的C程序,该程序有望输出
$ ./kill_raise
Child(pid : 4877) is waiting for any signal
Parent kill 4877
但我得到了
父母杀死4877
子进程中的字符串(Child(pid:%d)正在等待任何信号)没有打印出来,为什么?
这是我的程序
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/wait.h>
int main(int argc, char *argv[])
{
pid_t pid;
int res;
pid = fork();
if (pid < 0)
{
perror ("Fork error\n");
exit(0);
}
if (pid == 0)
{
printf ("child(pid:%d) is waiting for signal\n", getpid());
raise(SIGSTOP);
exit(0);
}
else
{
if ((waitpid(pid, NULL, WNOHANG)) == 0)
{
if ((res = kill(pid, SIGKILL)) == 0)
{
printf ("parent kill %d\n", pid);
}
}
waitpid(pid, NULL, 0);
exit(0);
}
}
答案 0 :(得分:1)
你正在点击race condition。父进程在子进程执行printf之前执行kill。删除WNOHANG,以便父母实际上等待孩子停止。此外,您需要添加WUNTRACED以便waitpid报告停止(默认情况下,它仅报告终止)。最后,在这种情况下,你不应该测试wait()的返回值为0。