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設置一個合理值。
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