我写了一小段代码。此代码首先阻止{SIGSEGV},然后将SIGRTMIN添加到同一组。所以,我最后的信号集是{SIGSEGV,SIGRTMIN}。因此,如果我使用SIG_UNBLOCK,按照我的理解,首先SIGRTMIN应该被解除阻塞,然后再次如果我调用SIG_UNBLOCK,SIGSEGV应该被解除阻塞。即,1){SIGSEGV,SIGRTMIN} 2)SIG_UNBLOCK =解锁SIGRTMIN,3)再次调用SIG_UNBLOCK =解锁SIGSEGV。 我只给SIGRTMIN一个进程,因此我的第二个unblock应该用SIGRTMIN停止进程。但事实并非如此。请帮忙。 N.B:请不要给出关于sigprocmask()上其他问题的答案的链接,我已经看到他们,他们也没有澄清我的问题。sigprocmask()在UNIX中阻止信号
enter code here
#include <signal.h>
#include <unistd.h>
#include <stdio.h>
int main()
{
sigset_t old_set,new_set;
sigemptyset(&old_set);
sigemptyset(&new_set);
if(sigaddset(&old_set,SIGSEGV)==0)
{
printf("sigaddset successfully added for SIGSEGV\n");
}
sigprocmask(SIG_BLOCK,&old_set,NULL); // SIGSEGV signal is masked
kill(0,SIGSEGV);
//*****************************************************************
if(sigaddset(&new_set,SIGRTMIN)==0)
{
printf("sigaddset successfully added for SIGRTMIN\n");
}
sigprocmask(SIG_BLOCK,&new_set,&old_set); // SIGRTMIN signal is masked
kill(0,SIGSEGV);
//****************** Unblock one signal at a time ******************
sigprocmask(SIG_UNBLOCK,&new_set,&old_set); // SIGRTMIN signal is unmasked
sigprocmask(SIG_UNBLOCK,&new_set,&old_set); // SIGSEGV signal is unmasked
}
Output:
[[email protected] signals]# ./a.out
sigaddset successfully added for SIGSEGV
sigaddset successfully added for SIGRTMIN
(Note:SIGSEGV is not received even after sigprocmask(SIG_UNBLOCK,&new_set,&old_set); a second time)
@ kubi:那么为什么我没有收到SIGSEGV? – kingsmasher1 2011-03-13 10:57:56
@ kubi:不,我不认为整套游戏一次就能畅通无阻。检查链接:http://stackoverflow.com/questions/25261/help-with-sigprocmask。此外,sigprocmask()本身不会阻塞或解除阻塞,它是使阻塞,解除阻塞或屏蔽的参数或第一个参数。所以,在指出我错误之前请先思考。 – kingsmasher1 2011-03-13 10:59:49
@ kingsmasher1:你如何处理'SIGSEGV'?你能粘贴一个信号处理程序代码片段吗?信号是否被正确发送?检查“sigprocmask”和“kill”的错误代码。 – kubi 2011-03-13 11:05:20