关于<signal.h>中SIG_ERR、SIG_DEL、SIG_IGN定义的问题

本文详细解析了Linux环境下signal.h中signal函数的使用方式及其SIG_ERR宏的含义,通过实例帮助读者理解函数参数和返回值的转换,并解释SIG_ERR为何不直接作为整数的原因。

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

linux中signal.h中对对signal的定义是:

void (*signal(int signo,void (*func)(int)))(int);

通过typedef可以转换成这样:

typedef void Sigfunc(int);
Sigfunc *signal(int,Sigfunc *);

也就是说,signal有两个参数,一个是int,一个是Sigfunc ,返回值也是Sigfunc ,该指针指向一个参数为int,无返回值的函数,然而,SIG_ERR的定义是这样的:

#define SIG_ERR (void (*)())-1
#define SIG_DEL (void (*)())0
#define SIG_IGN (void (*)())1

为什么不是这样定义的呢??

#define SIG_ERR (void (*)(int))-1
#define SIG_DEL (void (*)(int))0
#define SIG_IGN (void (*)(int))1

在网上搜索之后找到答案,C语言中是可以这样定义的:

void fun(); 
int main()
{
       fun(1,2);
} 
void fun(int i, int j)
{
      printf("%d\n",i+j);
}

只是将-1强制转换为一个指针,通过编译。就像#define NULL (void *)0。可以将SIG_ERR跟其他的信号理解的一样,是一个整数。

用信号的知识实现司机和售票员问题。 1)售票员捕捉SIGINT(代表开车)信号,向司机发送SIGUSR1信号,司机打印(let's gogogo) 2)售票员捕捉SIGQUIT(代表停车)信号,向司机发送SIGUSR2信号,司机打印(stop the bus) 3)司机捕捉SIGTSTP(代表到达终点站)信号,向售票员发送SIGUSR1信号,售票员打印(please get off the bus) 4)司机等待售票员下车,之后司机再下车。 分析:司机(父进程)、售票员(子进程) 司机: 捕捉: SIGUSR1、SIGUSR2、SIGTSTP 忽略:SIGINT、SIGQUIT 售票员: 捕捉:SIGINT、SIGQUIT、SIGUSR1 忽略:SIGTSTP #include <stdio.h> #include <signal.h> #include <unistd.h> #include <sys/types.h> #include <sys/wait.h> #include <stdlib.h> pid_t pid; void saler(int sig) { if (sig == SIGINT) { kill(getppid(), SIGUSR1); } else if (sig == SIGQUIT) { kill(getppid(), SIGUSR2); } else if (sig == SIGUSR1) { printf("please get off the bus\n"); } } void driver(int sig) { if (sig == SIGUSR1) printf("let's gogogo\n"); else if (sig == SIGUSR2) printf("stop the bus\n"); else if (sig == SIGTSTP) kill(pid, SIGUSR1); } int main() { pid = fork(); if (pid < 0) { perror("fork err"); return 1; } else if (pid == 0) // 售票员 { signal(SIGINT, saler); signal(SIGQUIT, saler); signal(SIGUSR1, saler); signal(SIGTSTP, SIG_IGN); } else // 司机 { signal(SIGUSR1, driver); signal(SIGUSR2, driver); signal(SIGTSTP, driver); signal(SIGINT, SIG_IGN); signal(SIGQUIT, SIG_IGN); wait(NULL); exit(0); } while (1) pause(); return 0; }
最新发布
05-28
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值