Linux信号掩码(signal mask)

Linux信号掩码简单来说就是如果在某一时刻信号如果包含在进程掩码中,则进程会暂时屏蔽此信号,直到其从进程信号掩码移除为止。

在POSIX下,每个进程有一个信号掩码(signal mask)。简单地说,信号掩码是一个“位图”,其中每一位都对应着一种信号。如果位图中的某一位为1,就表示在执行当前信号的处理程序期间相应的信号暂时被“屏蔽”,使得在执行的过程中不会嵌套地响应那种信号。

为什么对某一信号进行屏蔽呢?我们来看一下对CTRL+C的处理。大家知道,当一个程序正在运行时,在键盘上按一下CTRL+C,内核就会向相应的进程发出一个SIGINT信号,而对这个信号的默认操作就是通过do_exit()结束该进程的运行。但是,有些应用程序可能对CTRL+C有自己的处理,所以就要为SIGINT另行设置一个处理程序,使它指向应用程序中的一个函数,在那个函数中对CTRL+C这个事件作出响应。但是,在实践中却发现,两次CTRL+C事件往往过于密集,有时候刚刚进入第一个信号的处理程序,第二个SIGINT信号就到达了,而第二个信号的默认操作是杀死进程,这样一来第一个信号的处理程序根本没有执行完。为了避免这种情况的出现,就在执行一个信号处理程序的过程中将该种信号自动屏蔽掉。所谓“屏蔽”,与将信号忽略是不同的,它只是将信号暂时“遮盖”一下,一旦屏蔽去掉,后续收到的该信号又继续得到处理。

Linux内核中有一个专门的函数集合来执行设置和修改信号掩码,它们放在kernel/signal.c中,其函数形式和功能如下:

int sigemptyset(sigset_t *mask)                  清空信号集

int sigfillset(sigset_t *mask, int signum)       在信号集中设置所有信号  

int sigdelset(sigset_t *mask, int signum)        从信号集中删除signum信号

int sigaddset(sigset_t *mask, int signum)        在信号集中添加signum信号

int sigisnumber(sigset_t *mask, int signum)      测试信号signum是否在信号集中

 另外,进程也可以利用sigprocmask()系统调用改变和检查自己的信号掩码的值,其实现代码在kernel/signal.c中,原型为:

int sys_sigprocmask(int how, sigset_t *set, sigset_t *oset)

其中,set是指向信号掩码的指针,进程的信号掩码是根据参数how的取值设置成set;参数how的取值及含义如下:

SIG_BOLCK          :新的进程信号掩码是其当前值和set指定信号集的并集;

SIG_UNBOCK       :新的进程信号掩码是其当前值和~set信号集的交集,因此set指定的信号集将不被屏蔽;

SIG_SETBLOCK   :直接将进程信号掩码设为set;

第三个参数oset也是指向信号掩码的指针,它将包含以前的信号掩码值,使得在必要的时候可以恢复它。

进程可以用sigpending()系统调用来检查是否有挂起的阻塞信号。

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值