2.25、sigprocmask函数使用

1.sigprocmask函数使用介绍

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

    int sigpending(sigset_t *set);
        - 功能:获取内核中的未决信号集
        - 参数:set,传出参数,保存的是内核中的未决信号集中的信息。

2.sigpromask函数使用

#include <iostream>
#include <signal.h>
#include <cstdlib>
#include <unistd.h>

using namespace std;

int main()
{
    sigset_t set;
    sigemptyset(&set);

    // 设置2,3号两个信号阻塞

    sigaddset(&set, SIGINT);
    sigaddset(&set, SIGQUIT);

    int ret = sigprocmask(SIG_BLOCK, &set, NULL);
    if (ret == -1)
    {
        perror("sigprocmask");
        exit(0);
    }

    int num = 0;
    while (1)
    {
        num ++ ;

        sigset_t pending;
        sigemptyset(&pending);
        sigpending(&pending);

        for (int i = 1; i <= 31; i ++ )
        {
            int sigRet = sigismember(&pending, i);
            if (sigRet == 1)
                cout << 1;
            else if (sigRet == 0)
                cout << 0;
            else if (sigRet == -1)
            {
                perror("sigismember");
                exit(0);
            }
        }
        cout << endl;
        if (num == 20)
        {
            ret = sigprocmask(SIG_UNBLOCK, &set, NULL);
            if (ret == -1)
            {
                perror("sigprocmask");
                exit(0);
            }
        }
        sleep(1);
    }

    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`sigprocmask` 函数是一个系统调用,用于设置进程的信号屏蔽字,用于控制信号的传递。该函数有三个参数:`how` 表示如何修改信号屏蔽字,`set` 表示新的信号屏蔽字,`oldset` 表示旧的信号屏蔽字。 `how` 参数可以取以下三个值: - `SIG_BLOCK`:将 `set` 中的信号添加到当前进程的信号屏蔽字中。 - `SIG_UNBLOCK`:将 `set` 中的信号从当前进程的信号屏蔽字中移除。 - `SIG_SETMASK`:将当前进程的信号屏蔽字替换为 `set` 中的信号屏蔽字。 `set` 参数是一个指向 `sigset_t` 类型的指针,表示新的信号屏蔽字。`sigset_t` 是一个用于存储信号集合的类型,可以使用 `sigemptyset`、`sigfillset`、`sigaddset`、`sigdelset` 等函数来进行初始化和操作。 `oldset` 参数是一个指向 `sigset_t` 类型的指针,表示旧的信号屏蔽字。如果该参数不为 `NULL`,则 `sigprocmask` 函数会将当前进程的信号屏蔽字存储到 `oldset` 指向的内存中。 以下是一个示例代码,演示了如何使用 `sigprocmask` 函数设置信号屏蔽字: ```c #include <stdio.h> #include <signal.h> int main() { sigset_t set, oldset; sigemptyset(&set); sigaddset(&set, SIGINT); sigprocmask(SIG_BLOCK, &set, &oldset); printf("signal mask has been set to block SIGINT\n"); // do something sigprocmask(SIG_SETMASK, &oldset, NULL); printf("signal mask has been restored\n"); return 0; } ``` 在上面的示例中,我们首先使用 `sigemptyset` 和 `sigaddset` 函数初始化 `set`,将 `SIGINT` 信号添加到信号集合中。然后使用 `sigprocmask` 函数将 `SIGINT` 信号添加到当前进程的信号屏蔽字中,从而屏蔽该信号。在处理完需要屏蔽信号的任务后,我们使用 `sigprocmask` 函数将信号屏蔽字恢复为原始状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值