共计 1818 个字符,预计需要花费 5 分钟才能阅读完成。
这篇文章主要为大家展示了“Linux 中信号集操作函数有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让丸趣 TV 小编带领大家一起研究并学习一下“Linux 中信号集操作函数有哪些”这篇文章吧。
信号从产生到抵达目的地,叫作信号递达。而信号从产生到递达的中间状态,叫作信号的未决状态。产生未决状态的原因有可能是信号受到阻塞了,也就是信号屏蔽字 (或称阻塞信号集,mask) 对应位被置 1。阻塞信号集和未决信号集均是由内核维护的,整个过程如下图示:
我们有时需要屏蔽某个信号,就需要去修改阻塞信号集。那么,我们该如何修改阻塞信号集? 系统提供的一个方法是,我们先创建一个跟阻塞信号集一样的集合,再利用它去修改阻塞信号集。
系统提供了一系列的信号集设定函数。这些函数如下所示:
sigset_t set; 信号集数据类型,本质是 typedef unsigned long sigset_t; int sigemptyset(sigset_t *set); 将某个信号集清 0 int sigfillset(sigset_t *set); 将某个信号集置 1 int sigaddset(sigset_t *set, int signum); 将某个信号加入信号集 int sigdelset(sigset_t *set, int signum); 将某个信号清出信号集以上几个函数返回值均是:成功:0;失败:-1 int sigismember(const sigset_t *set, int signum); 判断某个信号是否在信号集中返回值:在集合:1;不在:0;出错:-1
使用以上这些函数创建完信号集后,要如何去改变阻塞信号集呢? 系统又提供了一个函数:sigprocmask 函数。
sigprocmask 函数可以用来屏蔽信号,也可以用来解除屏蔽信号,其本质就是利用我们创建的信号集去改变阻塞信号集。
函数原型:
int sigprocmask(int how, const sigset_t set, sigset_t oldset);
返回值:
成功:0; 失败:-1,设置 errno
参数解释:
set:传入参数,是一个位图,set 中哪位置 1,就表示当前进程屏蔽哪个信号。
oldset:传出参数,保存旧的信号屏蔽集。这个与 setitimer 有点相似。
how 参数取值:
假设当前的信号屏蔽字为 mask
SIG_BLOCK:当 how 设置为此值,set 表示需要屏蔽的信号。相当于 mask = mask | set
SIG_UNBLOCK:当 how 设置为此,set 表示需要解除屏蔽的信号。相当于 mask = mask ~set
SIG_SETMASK:当 how 设置为此,set 表示用于替代原始屏蔽及的新屏蔽集。相当于 mask = set 若,调用 sigprocmask 解除了对当前若干个信号的阻塞,则在 sigprocmask 返回前,至少将其中一个信号递达。
我们如何读取未决信号集? 系统提供了 sigpending 函数。
函数原型:
int sigpending(sigset_t *set);
参数说明:set 传出参数。
返回值:
返回值:成功:0; 失败:-1,设置 errno
例:把所有常规信号的未决状态打印至屏幕。
#include #include #include void printPending(sigset_t *set) { int i = 0; for (i = 0; i 32; i++) { if (sigismember(set, i) == 1) printf(1 else printf( 0 } printf(\n } int main() { sigset_t set, oldset, pendset; sigemptyset( set); sigaddset(set, SIGQUIT); // ctrl + \ 将产生 SIGQUIT 信号 sigprocmask(SIG_BLOCK, set, oldset); while (1) { sigpending( pendset); printPending(pendset); // 写一个函数打印未决信号集 sleep(1); } }
以上是“Linux 中信号集操作函数有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注丸趣 TV 行业资讯频道!