问题描述
- linux sigprocmask的问题
-
学习sigprocmask,发现sigpromask有时返回的oset是调用sigprocmask前信号的屏蔽集(截图中的“程序启动时”),有时返回的oset又是调用sigprocmask后信号屏蔽集(截图中的“收到SIGUSR2信号”)。为了方便各位大神测试,贴出代码:
#include
#include
#include
#include
#includevoid printsigset(sigset_t *set) //打印信号集中的各个位
{
int i;
for(i=1;i<NSIG;i++)
{
if(sigismember(set,i)) putchar('1');
else putchar('0');
}
printf("
");
}void handle_sigusr2(int sig)
{
sigset_t set,oset; //添加新的阻塞信号SIGUSR2,并打印出当前信号屏蔽字oset
sigemptyset(&set);
sigemptyset(&oset);
sigaddset(&set,SIGUSR2);
sigprocmask(SIG_BLOCK,&set,&oset);printsigset(&oset);
}int main(void)
{
signal(SIGUSR2,handle_sigusr2);//添加新的阻塞信号SIGUSR1,并打印出当前信号屏蔽字oset
sigset_t set,oset;
sigemptyset(&set);
sigemptyset(&oset);
sigaddset(&set,SIGUSR1);
sigprocmask(SIG_BLOCK,&set,&oset);
printsigset(&oset);
for(;;) pause();
return 0;
}
解决方案
If oldset is non-null, the previous value of the signal mask is stored in oldset.
你调用一次那个函数,确实设置了屏蔽字。不过oset那里返回的是之前的信号屏蔽字。。。
你再调用一次sigprocmask(0,NULL,&oset)就可以看到当前设置的信号屏蔽字了
解决方案二:
(转)Linux sigprocmask
linux 信号量sigprocmask使用
解决方案三:
man 一下sigprocmask,发现是这样描述---- If oldset is non-NULL, the previous value of the signal mask is stored
in oldset.
可见,oset指阿是之前的信号屏蔽字。既然如此,为何接到SIGURS2后oset返回有两个1呢?