【Unix环境高级编程】sigprocmask函数与sigpending函数

sigprocmask函数:

功能描述:
设定对信号屏蔽集内的信号的处理方式(阻塞或不阻塞)。


用法:
#include <signal.h>

int sigprocmask(int how, const sigset_t *set, sigset_t *oldset);

NOTE: If oldset is non-null, the previous value of the signal mask is stored in oldset.
参数:
how:用于指定信号修改的方式,可能选择有三种

SIG_BLOCK //加入信号到进程屏蔽。
SIG_UNBLOCK //从进程屏蔽里将信号删除。

SIG_SETMASK //将set的值设定为新的进程屏蔽。

相应函数命令:

sigset_t set

sigemptyset(&set) :清空阻塞信号集合变量

sigfillset(&set) :添加所有的信号到阻塞集合变量里

sigaddset(&set,SIGINT):添加单一信号到阻塞信号集合变量

sigdelset(&set,SIGINT):从阻塞信号集合变量中删除单一信号

sigismember(&set,int signum):这个函数测试信号signum是否包含在信号集合set中,如果包含返回1,不包含返回0,出错返回-1。错误代码也只有一个EINVAL,表示signum不是有效的信号代码。

sigpending 函数:

功能:返回在阻塞期间接收到阻塞信号的集合。

#include"apue.h"
static void sig_quit(int);

int main(void)
{
    sigset_t newmask,oldmask,pendmask;
    if(signal(SIGQUIT,sig_quit)==SIG_ERR)
        err_sys("cant catch SIGQUIT");//对SIGQUIT阻塞,保存当前信号屏蔽字
    sigemptyset(&newmask);
    sigaddset(&newmask,SIGQUIT);
    if(sigprocmask(SIG_BLOCK,&newmask,&oldmask)<0)
        err_sys("SIG_BLOCK error");

    sleep(5);//SIGQUIT当前还是未决状态

    if(sigpending(&pendmask)<0)
        err_sys("sigpending error");
    if(sigismember(&pendmask,SIGQUIT))
        printf("\nSIGQUIT pending\n");

    if(sigprocmask(SIG_SETMASK,&oldmask,NULL)<0)
        err_sys("SIG_SETMASK error");
    printf("SIGQUIT unblocked\n");
    sleep(5);//SIGQUIT will terminate with core file
    exit(0);
}
static void sig_quit(int signo)
{
    printf("caught SIGQUIT\n");
    if(signal(SIGQUIT,SIG_DFL)==SIG_ERR)
    {
        err_sys("cant reset SIGQUIT");
    }
}


在休眠期间如果产生了退出信号,此时该信号是未决的,但是不再阻塞。

然后该进程再休眠五秒,此期间在产生退出信号,此时信号处理方式为默认动作,这一次会是进程终止。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值