2.25sigprocmask函数

用于系统信号集

/*
    #include <signal.h>
    int sigprocmask(int how, const sigset_t *set, sigset_t *oldset);
        功能:将自定义信号集中的数据设置到内核中(设置阻塞,解除阻塞,替换)
        参数:
            how:如何对内核阻塞信号集进行处理
                SIG_BLOCK:将用户设置的阻塞信号集添加到内核中,内核中原来的数据不变
                    假设内核中默认的阻塞信号集是mask, mask | set
                SIG_UNBLOCK:根据用户设置的数据,对内核中的数据进行解除阻塞
                    mask & = ~set
                SIG_SETMASK:覆盖内核中原来的值
            
            set:已经初始化好的用户自定义的信号集
            oldset:保存设置之前内核中的阻塞信号集,不用的话就NULL
        返回值:
            成功:0
            失败:-1并设置错误号EFAULT、EINVAL
    #include <signal.h>
    int sigpending(sigset_t *set);
        功能:获取内核中的未决信号集
        参数:set,传出参数,保存的是内核中的未决信号集中的信息
        返回值:0成功,-1失败
*/

//把所有的常规信号(1-31)的未决状态打印到屏幕
//设置某些信号是阻塞的,通过键盘产生这些信号
#include <stdio.h>
#include <signal.h>
#include <stdlib.h>
#include <unistd.h>
int main(){
    //设置2、3号信号阻塞
    sigset_t set;
    sigemptyset(&set);

    //将2、3信号添加到信号集中
    sigaddset(&set,SIGINT);
    sigaddset(&set,SIGQUIT);

    //修改内核中的阻塞信号集
    sigprocmask(SIG_BLOCK,&set,NULL);
    int num=0;
    while(1){
        num++;
        //获取当前的未决信号集的数据
        sigset_t pendingset;
        sigemptyset(&pendingset);
        sigpending(&pendingset);

        //遍历前32位
        for(int i=1;i<=31;i++){
            if(sigismember(&pendingset,i)==1)
            {
                printf("1");
            }else if(sigismember(&pendingset,i)==0)
                printf("0");
            else
            {
                perror("sigismember");
                exit(0);
            } 
        }
        printf("\n");
        sleep(1);
        if(num==10){
            //解除阻塞
            sigprocmask(SIG_UNBLOCK,&set,NULL);
        }
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值