在c,linux中,关于kill和raise

时间:2017-02-28 03:14:02

标签: c linux signals

我在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);

    }
}

1 个答案:

答案 0 :(得分:1)

你正在点击race condition。父进程在子进程执行printf之前执行kill。删除WNOHANG,以便父母实际上等待孩子停止。此外,您需要添加WUNTRACED以便waitpid报告停止(默认情况下,它仅报告终止)。最后,在这种情况下,你不应该测试wait()的返回值为0。