考虑以下程序:
void handler(int signum){
printf("handling %d\n",signum);
}
int main() {
signal(SIGINT,handler);
sigset_t *ss;
sigemptyset(ss);
sigaddset(ss,SIGINT);
sigprocmask(SIG_BLOCK,ss,NULL);
for(;;);
return 0;
}
在终端中运行该程序后,当我按下ctrl-c时,我总是得到“处理2”作为输出,但我希望没有输出,因为SIGINT先前被阻止了.我错误地阻止了SIGINT吗?通过假设在从内核模式进入用户模式的过程中不会处理阻塞信号,我是否误解了阻塞信号意味着什么?
最佳答案
@Useless正确地回答了这个问题,说明你是通过将一个未初始化的指针传递给sig *函数来调用UB的.
至于为什么它的工作原理并且没有崩溃或者没有阻止SIGINT如果你添加这条线就可以清楚 –
printf("%p",ss);
这很可能是打印(零)或0.
幸运的是,未初始化的变量设置为NULL,并且来自sigprocmask
的文档
If
set
isNULL
,then the signal mask is unchanged (i.e.,how is
ignored),but the current value of the signal mask is nevertheless
returned inoldest
(if it is notNULL
).
因此,您对SIGINT的阻止实际上被忽略了.但是,如果你不幸运的话,你也可能会看到崩溃或其他一些(甚至是正确的行为).
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。