c++ 信號(hào)處理
信號(hào)是由操作系統(tǒng)傳給進(jìn)程的中斷,會(huì)提早終止一個(gè)程序。在 unix、linux、mac os x 或 windows 系統(tǒng)上,可以通過(guò)按 ctrl+c 產(chǎn)生中斷。
有些信號(hào)不能被程序捕獲,但是下表所列信號(hào)可以在程序中捕獲,并可以基于信號(hào)采取適當(dāng)?shù)膭?dòng)作。這些信號(hào)是定義在 c++ 頭文件 中。
信號(hào) | 描述 |
---|---|
sigabrt | 程序的異常終止,如調(diào)用 abort。 |
sigfpe | 錯(cuò)誤的算術(shù)運(yùn)算,比如除以零或?qū)е乱绯龅牟僮鳌?/td> |
sigill | 檢測(cè)非法指令。 |
sigint | 接收到交互注意信號(hào)。 |
sigsegv | 非法訪問(wèn)內(nèi)存。 |
sigterm | 發(fā)送到程序的終止請(qǐng)求。 |
1. signal() 函數(shù)
c++ 信號(hào)處理庫(kù)提供了 signal 函數(shù),用來(lái)捕獲突發(fā)事件。以下是 signal() 函數(shù)的語(yǔ)法:
void (*signal (int sig, void (*func)(int)))(int);
這個(gè)函數(shù)接收兩個(gè)參數(shù):第一個(gè)參數(shù)是一個(gè)整數(shù),代表了信號(hào)的編號(hào);第二個(gè)參數(shù)是一個(gè)指向信號(hào)處理函數(shù)的指針。
讓我們編寫一個(gè)簡(jiǎn)單的 c++ 程序,使用 signal() 函數(shù)捕獲 sigint 信號(hào)。不管您想在程序中捕獲什么信號(hào),您都必須使用 signal 函數(shù)來(lái)注冊(cè)信號(hào),并將其與信號(hào)處理程序相關(guān)聯(lián)??纯聪旅娴膶?shí)例:
#include #include #include using namespace std; void signalhandler( int signum ) { cout << "interrupt signal (" << signum << ") received.\n"; // 清理并關(guān)閉 // 終止程序 exit(signum); } int main () { // 注冊(cè)信號(hào) sigint 和信號(hào)處理程序 signal(sigint, signalhandler); while(1){ cout << "going to sleep...." << endl; sleep(1); } return 0; }
當(dāng)上面的代碼被編譯和執(zhí)行時(shí),它會(huì)產(chǎn)生下列結(jié)果:
going to sleep.... going to sleep.... going to sleep....
現(xiàn)在,按 ctrl+c 來(lái)中斷程序,您會(huì)看到程序捕獲信號(hào),程序打印如下內(nèi)容并退出:
going to sleep.... going to sleep.... going to sleep.... interrupt signal (2) received.
2. raise() 函數(shù)
您可以使用函數(shù) raise() 生成信號(hào),該函數(shù)帶有一個(gè)整數(shù)信號(hào)編號(hào)作為參數(shù),語(yǔ)法如下:
int raise (signal sig);
在這里,sig 是要發(fā)送的信號(hào)的編號(hào),這些信號(hào)包括:sigint、sigabrt、sigfpe、sigill、sigsegv、sigterm、sighup。以下是我們使用 raise() 函數(shù)內(nèi)部生成信號(hào)的實(shí)例:
#include #include using namespace std; void signalhandler( int signum ) { cout << "interrupt signal (" << signum << ") received.\n"; // 清理并關(guān)閉 // 終止程序 exit(signum); } int main () { int i = 0; // 注冊(cè)信號(hào) sigint 和信號(hào)處理程序 signal(sigint, signalhandler); while(++i){ cout << "going to sleep...." << endl; if( i == 3 ){ raise( sigint); } sleep(1); } return 0; }
當(dāng)上面的代碼被編譯和執(zhí)行時(shí),它會(huì)產(chǎn)生下列結(jié)果,并會(huì)自動(dòng)退出:
going to sleep.... going to sleep.... going to sleep.... interrupt signal (2) received.