信号捕捉 、pause函数和SIGCHLD信号

本文深入探讨了信号捕捉机制,包括信号如何在适当时机被处理,pause函数如何使进程挂起直至信号到达,以及SIGCHLD信号如何帮助解决僵尸进程问题。通过自定义信号处理函数,父进程可以有效地管理和响应子进程的退出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、信号捕捉

信号捕捉针对于自定义的函数处理信号方式。信号递达调用这个函数称为捕捉信号。发生信号并不是立即处理的,而是找合适的机会,这个机会就是从内核态切换到用户态的时候处理信号。

用户态切换到内核态的方式:(1)系统调用(2)程序异常(3)软件中断

信号捕捉流程顺序见下图:

 二、pause函数

调用pause函数回事进程挂起,直到有信号递达。如果信号的处理动作是终止进程,则进程终止,pause函数没有机会返回。

如果信号的处理动作是忽略的,则进程继续处于挂起状态,pause不返回。如果信号的处理动作为捕捉,则调用处理函数之后pause函数返回-1,error设置为EINTR,所以pause只有出错返回值,没有成功返回值和我们之前讲过的程序替换函数一样。

三、SIGCHLD信号

我们之前涉及到的僵尸进程,是由于子进程先于父进程退出,父进程没有关心子进程的退出状态导致僵尸进程。其实子进程退出会给父进程发送一个信号就是SIGCHLD。之前避免僵尸进程一种方法就是阻塞式的等待,父进程就不能处理自己的工作。第二种就是waitpid轮询等待的方式,但是这种父进程一边要处理自己的工作,另外一边还要轮询查询子进程是否结束,这样程序实现起来比较复杂。

我们可以使用该信号来处理僵尸进程,通过对该信号的自定义处理函数,然后父进程只管处理自己的事情,如果该信号到来父进程去处理,处理完毕之后接着做父进程的事情。

#include<stdio.h>
#include<unistd.h>
#include<stdlib.h>
#include<signal.h>
#include<sys/wait.h>
void sigcb(int signo)
{
  while(waitpid(-1,0,WNOHANG)>0)
  {
    printf("signo:%d\n",signo);
  }
}

int main()
{
  signal(SIGCHLD,sigcb);
  int pid = fork();
  if(pid<0)
  {
    perror("fork error");
    exit(1);
  }
  else if(pid == 0)
  {
    sleep(5);
    exit(1);
  }
  else 
  {
    while(1)
    {
      printf("waiting!!!\n");
      sleep(1);
    }
  }
  return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

weixin_41318405

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

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

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

打赏作者

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

抵扣说明:

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

余额充值