我是 Unix 中的信号新手,这个练习的目的是禁用 SIGINT 来停止程序并使用 SIGQUIT 代替,当我按下 ctrl-c 时它成功地忽略了 SIGINT 但 printf 没有显示,直到我按下 Ctrl-/这是针对 SIGQUIT 的,所有消息都会同时出现。
示例:如果我按 ctrl-c 4 次,则 ctrl-/:只有在按 ctrl-\ 后,我才会收到 4 条消息,说我已按 Ctrl-c,然后退出您发送了 SIGQUIT 信号。
如果我只按 ctrl-c,我什么也得不到,但至少它被忽略了
struct sigaction action;
void hand(int sig)
{
switch(sig){
case SIGINT:
printf("You have presed ctrl-c");
break;
case SIGQUIT:
printf("Quittin you sent a SIGQUIT signal");
exit(SIGQUIT);
break;
default:
printf("WRONG SIGNAL");
exit(-1);
break;
}
}
int main()
{
action.sa_handler=hand;
printf("Ctrl-C disabled, press Ctrl-/ to quit...\n");
sigaction(SIGINT,&action,NULL);
sigaction(SIGQUIT,&action,NULL);
while(1){
sleep(1);
}
}
Run Code Online (Sandbox Code Playgroud)
这里有两个问题。首先,printf默认情况下是行缓冲的,并且您没有打印换行符,因此在您期望时可能不会刷新输出缓冲区。其次,该printf函数不是异步信号安全的,这意味着在信号处理程序中调用它是未定义的行为。
更改您的信号处理程序以设置一个标志而不是打印,然后检查循环中的该标志并打印(\n在字符串的末尾)是否已设置。