第五部分:7---信号的捕捉

目录

信号递达期间,该信号会被屏蔽直到递达完成。

sigaction实现信号的捕捉:

案例:在处理2号信号时屏蔽3号信号。

子进程退出向父进程发送SIGCHLD信号:


信号递达期间,该信号会被屏蔽直到递达完成。

  • 当某个信号的处理函数被调用时,内核自动将当前信号加入进程的信号屏蔽字block中,当信号处理函数返回时自动恢复原来的信号屏蔽字。

  • 这样就保证了在处理某个信号时,如果这种信号再次产生,那么 它会被阻塞到当前处理结束为止。

  • 如果在调用信号处理函数时,除了当前信号被自动屏蔽之外,还希望自动屏蔽另外一些信号,则用sa_mask字段说明这些需要额外屏蔽的信号,当信号处理函数返回时自动恢复原来的信号屏蔽字。

sigaction实现信号的捕捉:

  • sigaction接口的功能类似于signal接口,但是在捕捉信号后,信号自定义函数的执行过程中,可以设置sa_mask字段来屏蔽一些其他的信号。防止同时处理这些信号

#include <signal.h>
int sigaction(int signum, const struct sigaction *act,struct sigaction *oldact);
//act表示自定义处理函数
//oldact,返回型参数,记录修改前的处理函数的地址

案例:在处理2号信号时屏蔽3号信号。

  • 通过设置struct sigaction 的 sigset_t sa_mask;成员,来达到上述目的。

  • 下面代码可以实现:在处理2号信号期间阻塞3号信号。

#include<iostream>
#include<unistd.h>
#include<signal.h>
using namespace std;
void handle(int sig)
{
    cout<<"i am signal:"<<sig<<endl;
}
int main()
{
    cout<<"pid : "<<getpid()<<endl;
    struct sigaction act,oldact; //创建两个struct sigaction结构体
    act.sa_handler=handle; //设置自定义信号处理函数
    sigemptyset(&act.sa_mask); //清空sa_mask
    sigaddset(&act.sa_mask,3); //向sa_mask添加要屏蔽的信号
    sigaction(2,&act,&oldact); //捕捉信号
    while(true)
    {
        sleep(1);
    }
    return 0;
}

子进程退出向父进程发送SIGCHLD信号:

  • 子进程在终止时会给父进程发SIGCHLD信号,该信号的默认处理动作是忽略。

  • 父进程可以自定义SIGCHLD信号的处理函数,在信号处理函数中调用wait清理子进程即可。这样父进程只需专心处理自己的工作,不必关心子进程了。

  • 如果需要获取子进程的退出信息,就需要wait等待子进程。但是如果不需要获取子进程的退出信息。可以使用以下代码,通过信号的方式回收子进程,使得父进程不用等待子进程。

signal(SIGCHLD,SIG_IGN); //这种方式只对Linux操作系统有效
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

S+叮当猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值