版权声明:欢迎关注公众号「Golang来了」交流。文章若有不妥之处请指正,欢迎转载,不过须注明出处~ https://blog.csdn.net/asd1126163471/article/details/75006771
1、作用
signal()是unix系统中最简单的信号机制接口函数,为指定的信号安装一个新的信号处理函数,换句话说就是改变信号的处理方法。
2、原型
#include<signal.h>
void ( *signal(int sig, void (*handler)(int)) )(int);
针对信号处理函数指针简化一下,便于理解:
//将sighandler_t定义为返回值为void,接受一个int形参的函数的指针
typedef void (*sighandler_t)(int);
//现在我们可以这样书写signal函数
sighandler_t signal(int sig, sighandler_t handler);
signal()函数第一个参数sig是信号名(参见:Linux信号(一)– 信号的基本概念);第二个参数,是一个无返回值、接收一个int形参的函数指针,指向对sig信号的处理函数。第二个参数有三种选择:
- SIG_IGN,向内核表示忽略此信号(SIGKILL和SIGSTOP不能忽略);
- SIG_DFL,表示接到此信号后的动作是系统的默认动作;
- 指定的函数地址,则在信号发生时会调用该函数。
signal()函数的返回值也是一个无返回值、接收一个int形参的函数指针,指向sig信号的处理程序;如果失败,则返回SIG_ERR。
如果查看系统的头文件signal.h,可以找到如下的声明:
#define SIG_ERR ( void (*) () )-1
#define SIG_DFL ( void (*) () )0
#define SIG_IGN ( void (*) () )1
这些常量可用于代替“指向函数的指针,该函数需要一个整型参数,而且无返回值”。
3、实例
#include <signal.h>
#include <stdio.h>
#include "unistd.h"
static void sig_usr(int signo);
int main(void)
{
if(signal(SIGUSR1,sig_usr)==SIG_ERR)
{
printf("signal(SIGUSR1) error\n");
return -1;
}
if(signal(SIGUSR2,sig_usr)==SIG_ERR)
{
printf("signal(SIGUSR2) error\n");
return -1;
}
for(;;)
{
pause(); //使调用进程在接收到一个信号前挂起
}
return 0;
}
static void sig_usr(int signo)
{
if(signo==SIGUSR1)
{
printf("received SIGUSR1\n");
}
else if(signo==SIGUSR2)
{
printf("received SIGUSR2\n");
}
else
{
printf("received signal:%d\n",signo);
}
}
编译之后在后台运行
./signal &
可以看到:
9507就是进程号,使用kill命令向进程发送命令: