简单常用的信号集操作函数

在这里我们先列出这些信号集操作函数,它们是:
int sigemptyset(sigset_t *set);
int sigfillset(sigset_t *set);
int sigaddset(sigset_t *set, int signo);
int sigdelset(sigset_t *set, int signo);
int sigismember(const sigset_t *set, int signo);
int sigprocmask(int how, const sigset_t *set, sigset_t *oset);

其中,signo是信号标志,我们可以用 kill -l查看,其中32-64为实时信号,这里先不讨论。
这里写图片描述

此外,sigset_t是一种结构体,sigset_t类型对于每种信号⽤用⼀个bit表⽰示“有效”或“无效”状态,至于怎么实现,我们作为使用者无须在意,其定义在/usr/include/bits/sigeset.h
这里写图片描述

  1. int sigemptyset(sigset_t *set);
    int sigfillset(sigset_t *set);
    函数sigemptyset初始化set所指向的信号集,使其中所有信号的对应bit清零,表示该信号集不包含任何有效信号。函数sigfillset初始化set所指向的信号集,使其中所有信号的对应bit置位,表示 该信号集的有效信号包括系统⽀支持的所有信号。
    **注意,在使⽤用sigset_t类型的变量之前,一定要调 sigemptyset或sigfillset做初始化,使信号集处于确定的状
    态**
    两个函数都是成功返回0,出错返回-1。
    2,int sigaddset(sigset_t *set, int signo);
    int sigdelset(sigset_t *set, int signo);
    我们在初始化sigset_t变量之后就可以 在调用sigaddset和sigdelset在该信号集中添加或删除某种有效信号。两个函数都是成功返回0,出错返回-1。

  2. int sigismember(const sigset_t *set, int signo);
    sigismember函数是一个布尔函数,⽤用于判断一个信号集的有效信号中是否包含某种 信号,若包含则返回1,不包含则返回0,出错返回-1。

4,int sigprocmask(int how, const sigset_t *set, sigset_t *oset);
调用函数sigprocmask可以读取或更改进程的信号屏蔽字(阻塞信号集)。
如果oset是非空指针,则读取进程的当前信号屏蔽字通过oset参数传出。如果set是非空指针,则 更改进程的信号屏蔽字,参数how指示如何更改。如果oset和set都是非空指针,则先将原来的信号 屏蔽字备份到oset⾥里,然后根据set和how参数更改信号屏蔽字。
how参数可为以下值:
SIG_BLOCK: set里面包含了我们想添加进屏蔽集里的信号。即mask = set | mask
SIG_UNBLOCK: set里面包含了我们去掉的信号。
即mask = ~set & mask
SIG_SETMASK:让当前信号屏蔽字与set相等
即mask = set
(mask 为当前信号屏蔽集)。
函数若成功则为0,若出错则为-1。

简单示例:
我们把一个信号(下面添加的是SIG_INT,即ctrl +c)添加到当前进程的屏蔽信号集里,这样我们发送的信号SIG_INT就不会被递达,而一直在未决信号集里,但是当计数器到达一个时限时,我们将信号屏蔽字变为原来的状态,未决信号集里的信号即可递达,程序终止。

void printblock(sigset_t* seg){//打印未决信号集。

    for (int i = 0; i < 32; i++){
    if (sigismember(seg, i) == 1)//判断是否有信号在*seg里
        printf("1");
    else printf("0");
    }
    printf("\n");

}




int main(){

     int i = 0;
     sigset_t seg, oseg, seg2;

     sigemptyset(&seg);
     sigaddset(&seg, SIGINT);//添加信号
     sigprocmask(SIG_BLOCK, &seg, &oseg);
    while (1){
     sleep(1);
     sigpending(&seg2);//获取当前的未决信号集
     printblock(&seg2);
      if (10 == i)
          sigprocmask(SIG_SETMASK, &oseg, NULL);
      i++;
      }


}

这里写图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值