Linux Signal (6): 信号屏蔽字

原创 2007年09月25日 15:46:00

1. 概念:

信号屏蔽字就是进程中被阻塞的信号集, 这些信号不能发送给该进程, 它们在该进程中被"屏蔽"了. 后面我们会提到, 实际上它们是被阻塞了.

2. 信号屏蔽函数:

#include <signal.h>

int sigprocmask(int how, const sigset_t *restrict set, sigset_t *restrict oset);

成功则返回0, 出错则返回
-1.

sigprocmask函数有3个参数:

  • how: 修改信号屏蔽字的方式.
  • set: 把这个信号集设为新的当前信号屏蔽字. 如果为NULL则不改变.
  • oset: 保存进程旧的信号屏蔽字. 如果为NULL则不保存.

参数中的how可以取3个值:

sigprocmask中的how参数
how 说明
SIG_BLOCK 修改后, 该进程新的信号屏蔽字是其当前屏蔽字和set指向的信号集的并集.
SIG_UNBLOCK 修改后, 该进程新的信号屏蔽字是其当前屏蔽字和set指向的信号集的补集的交集.
SIG_SETMASK 修改后, 该进程新的信号屏蔽字将被set指向的信号集的值代替

 另外要说的是, sigprocmask只为单线程定义的, 在多线程中要使用pthread_sigmask.

3. 未处理的信号:

在调用信号屏蔽的相关函数后, 被屏蔽的信号对于调用进程是阻塞的, 不能发送给调用进程, 因此是未决的. 取得这些阻塞的信号集, 可以通过调用sigpending函数.

#include <signal.h>

int sigpending(sigset_t *set);

成功则返回0, 出错则返回
-1.

4. 实例:

下面通过一个简单的实例来说明这篇文章中所讲到的两个函数.

#include <signal.h>
#include 
<unistd.h>
#include 
<stdlib.h>
#include 
<stdio.h>

/* SIGQUIT handler */
static void sig_quit(int signo)
{
    printf(
"SIGQUIT is caught "
);
}

int
 main()
{
    sigset_t 
new
, old, pend;

    
/* Handle SIGQUIT */

    
if (signal(SIGQUIT, sig_quit) == SIG_ERR)
    {
        perror(
"signal"
);
        exit(
1
);
    }

    
/* Add SIGQUIT to sigset */

    
if (sigemptyset(&new< 0)
        perror(
"sigemptyset"
);
    
if (sigaddset(&new, SIGQUIT) < 0
)
        perror(
"sigaddset"
);

    
/* Mask SIGQUIT */

    
if (sigprocmask(SIG_SETMASK, &new&old) < 0)
    {
        perror(
"sigprocmask"
);
        exit(
1
);
    }

    printf(
"SIGQUIT is blocked "
);
    printf(
"Now try Ctrl /  "
);

    sleep(
5); /* SIGQUIT will pending */


    
/* Get pending */
    
if (sigpending(&pend) < 0)
        perror(
"sigpending"
);

    
if (sigismember(&
pend, SIGQUIT))
        printf(
"SIGQUIT pending "
);

    
/* Restore signal mask */

    
if (sigprocmask(SIG_SETMASK, &old, NULL) < 0)
    {
        perror(
"sigprocmask"
);
        exit(
1
);
    }

    printf(
" SIGQUIT unblocked "
);
    printf(
"Now try Ctrl /  "
);

    sleep(
5
);

    
return 0
;
}

这个程序在开始的时候用sigprocmask屏蔽了SIGQUIT(ctrl+/触发), 在5秒内触发的该信号将可以从sigpending中获得; 然后程序把SIGQUIT解除屏蔽(恢复以前的屏蔽字), 此时再触发该信号将调用sig_quit信号处理函数.

 

相关文章推荐

signal 6 (SIGABRT), code -6 (SI_TKILL), fault addr

摘抄自:http://zhidao.baidu.com/link?url=gOXPCxE4HSq9GOGH0QGNS5zLXUWkeeHrmWpD_W3DrUllNLgJF7OGV4RCAEQGDGQ...

Linux Signal (6): 发送信号的kill和raise 函数

1. 函数说明:kill和raise是用来发送信号的:kill把信号发送给进程或进程组,它不仅可以中止进程,也可以向进程发送其他信号;raise把信号发送给(进程)自身.它们的原型如下:#includ...

关于linux signal 6 (SIGABRT)

关于linux signal 6 (SIGABRT)
  • ztguang
  • ztguang
  • 2016年11月26日 10:29
  • 1548

Android Fatal signal 6 (SIGABRT) at 0x0000271d (code=-6)

Android Fatal signal 6(SIGABRT) at 0x0000271d (code=-6)本人第一次在网上写文章,有什么好的地方请大家担待,有问题欢迎提出,一起讨论。下面我遇到的问...
  • qlx2522
  • qlx2522
  • 2015年07月28日 10:44
  • 10715

Linux Signal (6): 信号屏蔽字

 1. 概念:信号屏蔽字就是进程中被阻塞的信号集, 这些信号不能发送给该进程, 它们在该进程中被"屏蔽"了. 后面我们会提到, 实际上它们是被阻塞了.2. 信号屏蔽函数:#include int si...

linux signal 处理

源地址:http://blog.csdn.net/zhuixundelang/article/details/5979465 linuxsignal 处理   说明: 本文主要翻译自UL...
  • fz_ywj
  • fz_ywj
  • 2013年06月18日 22:13
  • 20184

调用信号处理程序被捕捉的信号自动地加到进程的当前信号屏蔽字中signal() sigpending()

//当调用一个信号处理程序时,被捕捉的信号自动地加到进程的当前信号屏蔽字中,阻止后来产生的这种信号中断改信号处理程序。 //当从信号处理程序返回时,自动恢复原来的屏蔽字 #include...

Linux c之 信号屏蔽字sigprocmask()

出处:http://blog.163.com/shaoyi1110@126/blog/static/7432840120124852546380/   int sigprocmask(int ho...

linux 信号屏蔽

#include #include #include #include #include #include /* sigemptyset(&newmask);//获取空屏蔽信号集 sig...

linux信号屏蔽

1、自定义SIGNAL函数。可设置在执行信号处理函数过程中,是否能被其它信号或者与当前信号相同信号中断。 2、使用sigprocmask函数进行信号屏蔽。 3、信号屏蔽过程中,向进程发送多个不同的信号...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Linux Signal (6): 信号屏蔽字
举报原因:
原因补充:

(最多只允许输入30个字)