在这里,我想在父母睡觉时向父母发送 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)
输出:输出仅打印这么多内容。我认为父母根本没有执行。
您需要在将 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)