信号集操作函数及其使用
信号集操作函数
类型sigset_t
从上面的图来看,每个信号只有一个bit的未决标志,非0即1,不记录该信号产生了多少次,阻塞标志也是这样表示的。
因此,未决和阻塞标志可以用相同的数据类型sigset_t来存储,sigset_t称为信号集,这个类型可以表示每个信号的“有效”或“无效”状态,在阻塞信号集中“有效”和“无效”的含义是该信号是否被阻塞,而在未决信号集中“有效”和“无效”的含义是该信号是否处于未决状态。
阻塞信号集也叫做当前进程的信号屏蔽字(Signal Mask),这里的“屏蔽”应该理解为阻塞而不是忽略。
不能对sigset_t进行你的原生操作,因为我们不知道他的底层里面都存放的是什么,它只是帮助我们拿到操作系统底层的数据,因此我们要对位图进行操作时要使用信号集操作函数。
信号集操作函数
- sigemptyset
sigemptyset是初始化set所指向的信号集,让其中所有的信号的对应的比特位清零,表示该信号集不包含任何有效信号。
#include <signal.h> int sigemptyset(sigset_t *set);
- sigfillset
sigfillset初始化set所指向的信号集,使其中所有信号的对应bit置位,表示该信号集的有效信号包括系统支持的所有信号。
#include <signal.h> int sigfillset(sigset_t *set);
- sigaddset
sigaddset把某个特定信号加上
#include <signal.h> int sigaddset(sigset_t *set, int signo);
- sigdelset
sigdelset把某个特定信号去掉
#include <signal.h> int sigdelset(sigset_t *set, int signo);
- signismember
signismember是为了判断某个信号是否在该信号集中。
#include <signal.h> int sigismember(const sigset_t *set, int signo);
- sigprocmask
sigprocmask(读取或更改进程的阻塞信号集)
调用函数sigprocmask可以读取或更改进程的信号屏蔽字(阻塞信号集)。#include <signal.h> int sigprocmask(int how, const sigset_t *set, sigset_t *oset);
返回值:若成功则为0,若出错则为-1
如果oset是非空指针,则读取进程的当前信号屏蔽字通过oset参数传出。如果set是非空指针,则 更改进程的信号屏蔽字,参数how指示如何更改。如果oset和set都是非空指针,则先将原来的信号 屏蔽字备份到oset里,然后根据set和how参数更改信号屏蔽字。假设当前的信号屏蔽字为mask,下表说明了how参数的可选值。
how参数 | 表示意义 |
---|---|
SIG_BLOCK | set包含了我们希望添加到当前信号屏蔽字的信号(往里加) |
SIG_UNBLOCK | set包含了我们希望从当前信号屏蔽字中解除阻塞的信号(往外减) |
SIG_SETMASK | 设置当前信号屏蔽字为set所指向的值(重新设置) |
如果调用sigprocmask解除了对当前若干个未决信号的阻塞,则在sigprocmask返回前,至少将其中一个信号递达。
- sigpending
sigpending:读取当前进程的未决信号集,通过set参数传出。(输出型参数)
#include <signal.h> int sigpending(sigset_t *set);
返回值:调用成功则返回0,出错则返回-1
具体使用示例代码
运行结果为:
本文涉及代码:
1 #include <stdio.h>
2 #include <signal.h>
3 #include <unistd.h>
4 void handler(int signo)
5 {
6 printf("get a signo is:%d\n",signo);
7 }
8 void show(sigset_t *pending)
9 {
10 int i=1;
11 for(;i<=31;i++){
12 if(sigismember(pending,i)){
13 printf("1");
14 }else{
15 printf("0");
16 }
17 }
18 printf("\n");
19 }
20 int main()
21 {
22 sigset_t set,oset;
23 sigemptyset(&set);
24 sigemptyset(&oset);
25 sigaddset(&set,2);
26 sigprocmask(SIG_SETMASK,&set,&oset);
27 signal(2,handler);
28
29 sigset_t pending;
30 int i=5;
31 while(1)
32 {
33 sigpending(&pending);
34 show(&pending);
35 sleep(1);
36 if(i-- ==0){
37 sigprocmask(SIG_SETMASK,&oset,NULL);
38 }
39 }
40 return 0;
41 }