天天看点

Linux Signal (2): signal函数

1. 原型:

Linux Signal (2): signal函数

#include  < signal.h >

Linux Signal (2): signal函数

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

Linux Signal (2): signal函数
Linux Signal (2): signal函数

成功则返回该信号以前的处理配置, 出错则返回SIG_ERR.

参数说明:

  • signo: 信号名, 如SIGINT.
  • func: 对应signo的信号处理函数的函数名, 这个函数没有返回值, 有一个整型参数, 这是捕捉的情况, 当然也可以是以下两种宏:
    • SIG_IGN: 忽略.
    • SIG_DFL: 默认动作.

2. 改写原型:

Linux Signal (2): signal函数

typedef  void  ( * sigfunc)( int );

Linux Signal (2): signal函数
Linux Signal (2): signal函数

sigfunc  * signal( int , sigfunc);

3. 三个宏定义:

#define SIG_ERR (void (*)()) -1 // 错误编号

#define SIG_DFL (void (*)()) 0  // 默认动作编号

#define SIG_IGN (void (*)()) 1  // 忽略编号

4. kill命令:

在shell里面执行kill命令可以向进程发送信号:

kill -USR1 7216 ;向pid为7216的进程发送SIGUSR1信号.

kill 7216       ;向pid为7216的进程发送SIGTERM信号.

5. 注意事项:

exec函数执行后, 把该进程所有信号设为默认动作.

exec函数执行后, 把原先要捕捉的信号设为默认, 其他不变.

fork之后, 子进程继承父进程的信号处理方式.

继续阅读