信号(signal)机制是Unix系统中最为古老的进程间通信机制,很多条件可以产生一个信号:
1、当用户按某些按键时,产生信号
2、硬件异常产生信号:除数为0、无效的存储访问等等。这些情况通常由硬件检测到,将其通知内核,然后内核产生适当的信号通知进程,例如,内核对正访问一个无效存储区的进程产生一个SIGSEGV信号
3、进程用kill函数将信号发送给另一个进程
1、当用户按某些按键时,产生信号
2、硬件异常产生信号:除数为0、无效的存储访问等等。这些情况通常由硬件检测到,将其通知内核,然后内核产生适当的信号通知进程,例如,内核对正访问一个无效存储区的进程产生一个SIGSEGV信号
3、进程用kill函数将信号发送给另一个进程
4、用户可用kill命令将信号发送给其他进程
下面是几种常见的信号:
§ SIGHUP: 从终端上发出的结束信号
§ SIGINT: 来自键盘的中断信号(Ctrl-C)
§ SIGKILL:该信号结束接收信号的进程,杀死进程
§ SIGTERM:kill 命令发出的信号
§ SIGCHLD:子进程停止或结束时通知父进程
§ SIGSTOP:来自键盘(Ctrl-Z)或调试程序的停止执行信号,暂停进程
当某信号出现时,将按照下列三种方式中
的一种进行处理:
1、忽略此信号
大多数信号都按照这种方式进行处理,但有两种信号
决不能被忽略,它们是:SIGKILL\SIGSTOP。
这两种信号不能被忽略的原因是:它们向超级用户提供了一种终止或停止进程的方法
2、执行用户希望的动作
通知内核在某种信号发生时,调用一个用户函数。在用户函数中,执行用户希望的处理
3、执行系统默认动作
对大多数信号的系统默认动作是终止该进程
发送信号的主要函数有 kill和raise。
区别:
Kill既可以向自身发送信号,也可以向其他进程发送信号。与kill函数不同的是,raise函数是向进程自身发送信号
kill
函数作用:传送信号给指定的进程
函数原型:int kill(pid_t pid,int sig)
函数参数:pid>0 指定的进程pid
pid=0发送给目前进程相同的进程组的所有进程
pid=-1 广播给系统内所有的进程
sig 信号
返回值:成功返回0,出错返回-1
头文件:#include <signal.h>
#include <sys/types.h>
raise
函数功能:发送信号给自身
函数原型:int raise(int sig)
头文件:#include <signal.h>
使用alarm函数可以设置一个时间值(闹钟时间),当所设置的时间到了时,产生SIGALRM信号.如果不捕捉此信号,则默认动作是终止该进程
alarm
函数作用:设置信号,传送闹钟
函数原型:unsigned int alarm(unsigned int secnds)
返回值:返回之前闹钟的剩余秒数,如果之前未设置闹钟则返回0
头文件:#include <signal.h>
#include <unistd.h>
pause
函数作用:让进程暂停直到信号出现
函数原型:int pause(void)
返回值:-1
signal
函数作用:设置信号处理方式
函数原型:void (*signal(int signum,void(*handler(int)))(int)
typedef void(*handler(int) signhandler_t
signhandler_t signal(int signnum,signhandler_t handler)
下面是例子:
#include <signal.h>
#include <stdio.h>
#include <stdlib.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()
{
printf("Waiting for signal SIGINT or SIGQUIT \n ");
/*注册信号处理函数*/
signal(SIGINT, my_func);
signal(SIGQUIT, my_func);
pause();
exit(0);
}