1

我从SE QUE获得了以下信息 将 SIGCHLD 的配置显式设置为 SIG_IGN 会导致任何随后终止的子进程立即从系统中删除,而不是被转换为僵尸。

据我所知,要读取子状态,进程表中需要有子 pid。所以有必要在进程表中有僵尸子进程来读取子状态。

所以我想编写信号处理程序,它将删除“将 SIGCHLD 的处置设置为 SIG_IGN”

我使用下面的代码(在 fork 之前)来避免在终止后立即删除子进程:但我仍然无法获得子进程并且 waitpid 使用 ECHILD 返回 -1。

#include <errno.h>
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>

static siginfo_t sig_info;
static volatile sig_atomic_t sig_num;
static void *sig_ctxt;

static void catcher(int signum, siginfo_t *info, void *vp)
{
    sig_num = signum;
    sig_info = *info;
    sig_ctxt = vp;
}

static void set_handler(int signum)
{
    struct sigaction sa;
    sa.sa_flags = SA_SIGINFO;
    sa.sa_sigaction = catcher;
    sigemptyset(&sa.sa_mask);

    if (sigaction(signum, &sa, 0) != 0)
    {
        int errnum = errno;
        fprintf(stderr, "Failed to set signal handler (%d: %s)\n", errnum, strerror(errnum));
        exit(1);
    }
}

static void prt_interrupt(FILE *fp)
{
    if (sig_num != 0)
    {
        fprintf(fp, "Signal %d from PID %d\n", sig_info.si_signo, (int)sig_info.si_pid);
        sig_num = 0;
    }
}

请提出一些想法,我被这个阻止了。

4

1 回答 1

0

而不是捕捉信号,只需在 main 中使用此代码:

signal(SIGCHLD,SIG_IGN);

不要使用处理程序,而是使用 SIG_IGN(如上所示)。这忽略了信号,进程 pid 将保留在进程表中。然后,父进程可以使用 waitpid() 或 wait() 声明此僵尸进程的状态。

于 2015-03-14T17:10:34.903 回答