从孩子向父母发送信号

Vij*_*esh 4 c signals

在这里,我想在父母睡觉时向父母发送 SIGINT 信号。我通过按照程序编写来尝试过。在这个程序中,我不明白为什么来自父级的 SIGINT 信号处理程序根本没有执行?这是代码:

#include<stdio.h>
#include<signal.h>
#include<unistd.h>
#include<stdlib.h>
void sig_usr(int signo){
    if(signo == SIGINT)
    printf("Signal caught!");
    return;
}

int main(void){
    pid_t pid, ppid;
    ppid = getpid();
    printf("ppid = %d\n", ppid);
    if((pid = fork()) == 0){ 
        printf("killing parent...\n");
        kill(ppid, SIGINT);
        printf("After killing parent...\n");
    }
    else{
        sleep(5);
        printf("%d %d ",ppid, pid);
        if(signal(SIGINT,sig_usr) == SIG_ERR)
            printf("Signal processed ");
    }
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

输出:输出仅打印这么多内容。我认为父母根本没有执行。

输出仅打印这么多内容。 我认为父母根本没有执行。

id0*_*d01 5

您需要在将 SIGINT 发送到父进程之前设置信号处理程序,否则将不会执行该处理程序。此外,父进程在执行任何操作之前都会被杀死。解决此问题的简单方法是在父进程的代码之后移动 sleep 调用,并向子进程添加延迟。

#include<stdio.h>
#include<signal.h>
#include<unistd.h>
#include<stdlib.h>
void sig_usr(int signo){
    if(signo == SIGINT)
    printf("Signal caught!");
    return;
}

int main(void){
    pid_t pid, ppid;
    ppid = getpid();
    printf("ppid = %d\n", ppid);
    if((pid = fork()) == 0){ 
        sleep(1); // Wait for parent to finish setting up
        printf("killing parent...\n");
        kill(ppid, SIGINT);
        printf("After killing parent...\n");
    }
    else{
        printf("%d %d ",ppid, pid);
        if(signal(SIGINT,sig_usr) == SIG_ERR)
            printf("Signal processed ");
        sleep(5); // Wait to be killed
    }
    return 0;
}
Run Code Online (Sandbox Code Playgroud)