信号概述:
它是在软件层次上对中断机制的一种模拟,是一种异步通信方式。信号可以直接进行用户空间进程和内核进程之间的交互,内核进程也可以利用它来通知用户空间进程发生了哪些系统事件。它可以在任何时候发给某一进程,而无需知道该进程的状态。如果该进程当前并未处于执行态,则该信号就由内核保存起来,直到该进程恢复执行再传递给它为止;如果一个信号被进程设置为阻塞,则该信号的传递被延迟,直到其阻塞被取消时才被传递给进程。
用户进程对信号的响应可以有 3 种方式。
· 忽略信号,即对信号不做任何处理,但是有两个信号不能忽略,即 SIGKILL 及SIGSTOP。
**· 捕捉信号,**定义信号处理函数,当信号发生时,执行相应的处理函数。
**· 执行缺省操作,**Linux 对每种信号都规定了默认操作。
Linux 中的大多数信号是提供给内核的,表 8.6 列出了 Linux 中最为常见信号的含义及其默认操作。
信号发送与捕捉:
发送信号的函数主要有 kill()、raise()、alarm()以及 pause(),下面就依次对其进行介绍。
1.kill()和 raise()
(1)函数说明:
kill 函数同读者熟知的 kill 系统命令一样,可以发送信号给进程或进程组(实际上,kill系统命令只是 kill 函数的一个用户接口)。这里要注意的是,它不仅可以中止进程(实际上发出 SIGKILL 信号),也可以向进程发送其他信号。与 kill 函数所不同的是,raise 函数允许进程向自身发送信号。
(2)函数格式:
表 8.7 列出了 kill 函数的语法要点:
案例:首先使用fork创建了一个子进程,接着为了保证子进程不在父进程调用kill之前退出,在子进程中使用 raise 函数向子进程发送 SIGSTOP 信号,使子进程暂停。接下来再在父进程中调用 kill 向子进程发送信号,在该示例中使用的是 SIGKILL,读者可以使用其他信号进行练习。
#include<stdio.h>
#include<stdlib.h>
#include<signal.h>
#include<sys/types.h>
#include<sys/wait.h>
int main()
{
pid_t pid;
int ret;
//创建一子进程
if((pid=fork())<0)
{
perror("fail to fork");
exit(1);
}
if(pid == 0)
{
//在子进程中使用raise函数发出SIGSTOP信号
raise(SIGSTOP);
exit(0);
}else{
//在父进程中收集子进程发出的信号,并调用kill函数进行相应的操作
printf("pid = %d\n",pid);
if((