TCP/IP网络编程笔记Chapter I -8进程与僵尸进程2

本文详细介绍了Linux系统中信号与信号处理函数signal()和sigaction(),并通过实例展示了如何利用信号技术来消除僵尸进程。在讲解过程中,提到了SIGALRM、SIGINT和SIGCHLD信号的处理,以及alarm()和waitpid()函数的应用。
摘要由CSDN通过智能技术生成


在上一篇中,我们知道了进程的创建以及销毁方法,但是还有一个问题困扰着我们:子进程究竟什么时候终止,调用waitpid()函数后需要无休止的等待吗?
子进程终止时识别的主体是操作系统,能不能让操作系统告诉父进程子进程终止了,让父进程暂时先处理子进程再继续工作呢?当然是可以的,我们引入信号处理机制。此时的 信号是在特定事件发生时由操作系统向进程发送的消息。而为了响应消息,也需要执行某些自定义的处理。

1.信号与signal()函数

首先我们需要注册信号,即当进程发现它的子进程结束时,请求操作系统调用的特定函数。信号注册函数原型如下:

#include<signal.h>
void (*signal(int signo,void (*func)(int)))(int);
  • 为了在产生信号时调用,返回之前注册的函数指针
  • 上述函数返回值类型为void函数指针
  • 函数名为signal,参数一为int signo,第二参数为void (*func)(int)
  • 返回类型:参数类型为int型,返回void型函数指针
  • 调用上述函数,发生第一个参数代表的情况时,调用第二个参数所指的函数

signal函数注册了部分特殊情况(第一参数)

  • SIGALRM:已到通过alarm函数注册的时间
  • SIGINT:输入CTRL+C
  • SIGCHILD:子进程终止

eg:
①子进程终止调用mychild函数

signal(SIGCHILD,mychild);

②到达alarm注册时间调用timeout函数

signal(SIGALRM,timeout);

③输入CTRL+C调用keycontrol函数

signal(SIGINT,keycontrol);

以上就是信号注册的过程,在验证前我们介绍下alarm函数。

#include<unistd.h>
unsigned int alarm(unsigned int seconds);
  • 返回0或以秒为单位距SIGALRM信号发生所剩的时间
  • 传入正整数seconds,在相应时间后产生SIGALRM信号;传递0则取消预约;未指定信号对应的处理函数则调用会signal终止进程。

下面将验证信号处理的相关实例
首先定义两个信号处理函数timeout、keycontrol并注册SIGALRM和SIGINT信号,之后提供100*3的等待时间,每隔两秒就会触发超时。

#include <stdio.h>
#include <unistd.h>
#include <signal.h>
 
void timeout(int sig)
{
   
    if (sig == SIGALRM)
        puts("Time out!");
    alarm(2);
}
void keycontrol(int sig)
{
   
    <
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值