Linux进程间通信 - 信号(signal)机制
1 概述
Linux和类Linux系统下进程间通信(Inter-Process Communication, IPC)有很多种方式,包括套接字(socket),共享内存(shared memory),管道(pipe),消息队列(message queue)等[1],各自有各自的一些应用场景和用途,这次就来总结一下通过信号(signal)的机制。
信号,是Linux中向进程发送的消息,接收到该信号的进程会相应地采取一些行动,即通过软中断的方式来响应这个信号,触发一些事先指定或特定的事件。进程之间可以互相通过系统调用kill来发送信号,内核也可以因为内部事件而给进程发送信号,通知进程发生了某件事件[2]。
2 signal的系统api使用
2.1 响应信号
程序可以用signal库函数来处理信号,它的定义如下:
#include <signal.h>
void (*signal(int sig, void (*func)(int)))(int);
这个定义表示,signal是一个带有sig和func两个参数的函数,其中func是一个函数指针,指向的函数带有1个int类型参数且无返回值,signal函数返回值也是一个带有1个int类型参数且无返回值的函数指针,关于函数指针和函数形式的分析可以参考我的另一篇文章《C - 函数指针》。signal函数作用是绑定信号值为sig的信号的响应时间为func指向的函数,即当捕获到sig信号时,调用func指向的函数(可称为信号处理函数),另外func也可以用下面两个特殊值之一来代替信号处理函数:
SIG_IGN 忽略信号
SIG_DFL 恢复默认行为
编写一个示例程序C代码:
#include <stdio.h>
#include <unistd.h>
#include <signal.h>
void laugh(int sig){
printf("Haha... this time catch you, signal %d\n",sig);
printf("We will restore to default.\n");
signal(sig,SIG_DFL);
}
int main(){
int s