程序经常会异常终止(比如段错误),或者认为终止(比如按下了CTRL+C),这时可能一些动态申请的资源就得不到释放,或者程序有些其他需要处理的操作(如保存)。
C语言的标准库<signal.h>中提供了一些用于处理处理程序运行期间的异常的功能,如处理来源于外部的中断信号或程序执行期间出现的错误等事件。
#include <signal.h>
void (*signal(int sig, void (*handler)(int)))(int);
signal()用于确定以后当信号sig出现时的处理方法。如果handler的值是SIG_DFL,那么就采用实现定义的缺省行为;如果handler的值是SIG_IGN,那么就忽略该信号;否则,调用handler所指向的函数(参数为信号类型)。有效的信号包括:
SIGABRT | 异常终止,如调用abort()。 |
SIGFPE | 算术运算出错,如除数为0或溢出。 |
SIGILL | 非法函数映象,如非法指令。 |
SIGINT | 交互式信号,如中断。 |
SIGSEGV | 非法访问存储器,如访问不存在的内存单元。 |
SIGTERM | 发送给本程序的终止请求信号。 |
当随后出现信号sig时,就中断正在执行的操作,转而执行信号处理函数(*handler)(sig)。如果从信号处理程序中返回,则从中断的位置继续执行。signal()返回信号sig原来的的handler;如果出错,则返回SIG_ERR。
例子:
1、除数为0
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
void func(int sig)
{
printf("Signal deal!\n");
printf("ERROR:Divisor is 0!\n");
exit(0);
}
int main()
{
signal(SIGFPE,func);
printf("10/0=\n",10/0);
return 0;
}
输出:
Signal deal!
ERROR:Divisor is 0!
2、程序被CTRL+C终止:
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
void func(int sig)
{
printf("Signal deal!\n");
printf("Signal was stop by ctrl+c!\n");
exit(0);
}
int main()
{
signal(SIGINT,func);
while(1){
sleep(1);
}
return 0;
}
按下CTRL+C,输出:
^CSignal deal!
Signal was stop by ctrl+c!