这里要说明的是 sigaction()函数中第 2 和第 3 个参数用到的 sigaction 结构, 这是一个看似非常复杂的结构, 希望读者能够慢慢阅读此段内容。
首先给出了 sigaction 的定义, 代码如下:
struct sigaction
{
void (*sa_handler)(int signo);
sigset_t sa_mask;
int sa_flags;
void (*sa_restore)(void);
}
sa_handler 是一个函数指针:
指定信号处理函数, 这里除可以是用户自定义的处理函数外, 还可以为 SIG_DFL(采用默认的处理方式) 或 SIG_IGN(忽略信号)。 它的处理函数只有一个参数, 即信号值。
sa_mask 是一个信号集:
它可以指定在信号处理程序执行过程中哪些信号应当被屏蔽,在调用信号捕获函数前, 该信号集要加入到信号的信号屏蔽字中。
sa_flags 中包含了许多标志位:
是对信号进行处理的各个选择项。
它的常见可选值如表
以下实例表明了如何使用sigaction()函数捕捉相应信号, 并做出给定的处理。这里, my_func就是信号处理的函数指针, 读者还可以将其改为 SIG_IGN 或 SIG_DFL 查看运行结果。
以下是使用 sigaction()函数的示例:
#include <stdio.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <sys/wait.h>
#include <sys/time.h>
#include <sys/resource.h>
#include <pwd.h>
#include <signal.h>
/* 自定义信号处理函数 */
void my_func(int sign_no)
{
if (sign_no == SIGINT)
{
printf("I have get SIGINT\n");
}else if (sign_no == SIGQUIT)
{
printf("I have get SIGQUIT\n");
}
}
int main()
{
struct sigaction action;
printf("Waiting for signal SIGINT or SIGQUIT...\n");
/* sigaction 结构初始化 */
action.sa_handler = my_func;
sigemptyset(&action.sa_mask);
action.sa_flags = 0;
/* 发出相应的信号, 并跳转到信号处理函数处 */
sigaction(SIGINT, &action, 0);
sigaction(SIGQUIT, &action, 0);
pause(); //等待一个信号
exit(0);
}
结果:
$ ./signal
Waiting for signal SIGINT or SIGQUIT...
I have get SIGINT (按 Ctrl+c 组合键)
$ ./signal
Waiting for signal SIGINT or SIGQUIT...
I have get SIGQUIT (按 Ctrl+\ 组合键)