副标题#e#
9. signal.h
头文件signal处理惩罚措施运行时发生的信号的要领。
宏:
SIG_DFL
SIG_ERR
SIG_IGN
SIGABRT
SIGFPE
SIGILL
SIGINT
SIGSEGV
SIGTERM
函数:
signal();
raise();
变量:
typedef sig_atomic_t
9.1. 变量和界说
范例sig_atomic_t就是int,作为signal函数的handler中的变量。SIG_宏用于signal函数顶用于界说信号函数。
SIG_DFL 默认handler。
SIG_ERR 暗示错误信号。
SIG_IGN 忽略信号。
SIG宏代表下列环境下的信号编号。
SIGABRT 异常终止(由abort函数发生)。
SIGFPE 浮点错误(由零除运行、不公道操纵发生)。
SIGILL 犯科操纵(指令)。
SIGINT 交互信号(好比我们熟悉的Ctrl-C)。
SIGSEGV 犯科存储会见(段错误,内存错误)。
SIGTERM 终止请求。
9.2. signal
声明:
void (*signal(int sig, void (*func)(int)))(int);
该函数打点一个信号应该如何被操控。sig代表与SIG宏相容的信号编号。func函数会在信号发生时被挪用。假如函数是SIG_DFL,则挪用默认的handler。假如func是SIG_IGN,则信号被忽略。假如func指向一个函数,那么当检测到一个信号并执行默认handler时,该函数会被挪用。函数必需携带一个int参数代表信号编号。函数大概被return,abort,exit,可能longjmp终止。当函数终止时,措施继承从间断处执行(除非是功效未界说的信号SIGFPE)。
假如信号挪用乐成,则返回指向之前特定信号范例的handler的指针。假如信号挪用失败,则返回SIG_ERR而且将errno配置一个公道值。
#p#副标题#e#
9.3. raise
声明:
int raise(intsig);
发生sig信号。sig参数要与SIG宏兼容。
假如挪用乐成,会返回0。不然返回非零值。
实例:
#include<signal.h> #include<stdio.h> void catch_function(int); int main(void) { if(signal(SIGINT, catch_function)==SIG_ERR) { printf("An error occured while setting a signal handler.\n"); exit(0); } printf("Raising the interactive attention signal.\n"); if(raise(SIGINT)!=0) { printf("Error raising the signal.\n"); exit(0); } printf("Exiting.\n"); return 0; } void catch_function(int signal) { printf("Interactive attention signal caught.\n"); }
措施运行输出功效(假设没有错误):
Raising the interactive attention signal. Interactive attention signal caught. Exiting.
英文原文:http://www.acm.uiuc.edu/webmonkeys/book/c_guide/2.9.html
原文作者:Eric Huss
中文译者:柳惊鸿 Poechant
版权声明:本文的原文版权归Eric Huss所有,中文译文版权归Poechant所有。转载请注明来自"柳大的CSDN博客":http://blog.csdn.net/poechant