Linux?signal()函數(shù)的使用學(xué)習(xí)
signal() 函數(shù)
無意中看到了 signal() 函數(shù),感覺對這個函數(shù)的原型有諸多疑惑,學(xué)習(xí)一下,順便分享。
1. 原型
Unix系統(tǒng)提供了signal()和sigaction()兩個函數(shù)來改變對于信號的處理方法。其中signal()是一個基于sigaction()系統(tǒng)調(diào)用的glibc庫函數(shù),其行為在不同的Unix操作系統(tǒng)存在差異,對于可移植性有要求的程序不能使用signal()函數(shù)。
其原型如下:
#include<signal.h> void ( *signal(int sig, void (*handler)(int)) )(int);
signal函數(shù)的第一個參數(shù)sig,要傳入希望修改處理函數(shù)的信號編號,第二個參數(shù),是一個無返回值、接受一個int形參的函數(shù)指針,指向?qū)ig信號的新處理函數(shù)。函數(shù)的第二個參數(shù)可以有三種選擇,第一種是我們自己定義的信號處理函數(shù),第二種是傳入SIG_DFL 表示將之前signal所改變的信號處理方式還原,第三種是傳入SIG_IGN,表示處理方式為忽略該信號,內(nèi)核會直接將信號丟棄,不會傳遞到進程。
signal函數(shù)的返回值同樣是一個無返回值、接受一個int形參的函數(shù)指針。當(dāng)signal()函數(shù)成功執(zhí)行時,返回值是執(zhí)行signal函數(shù)之前的sig信號的處理函數(shù)的指針,如果失敗,則返回SIG_ERR。
對信號處理函數(shù)指針做這樣的定義,可能便于理解:
//將sighandler_t定義為返回值為void,接受一個int形參的函數(shù)的指針 typedef void (*sighandler_t)(int); //現(xiàn)在我們可以這樣書寫signal函數(shù) sighandler_t signal(int sig, sighandler_t handler);
其實glibc里已經(jīng)有了如上的定義,只需要我們定義_GUN_SOURCE特性測試宏,就可以使用sighandler_t類型。
2.實例
以下用法用于暫時性修改某信號的信號處理函數(shù),在使用完之后,將信號處理函數(shù)重置為其原來版本。
void newhandler(int sig){ //code to handle the sig } void (*prevhandler)(int); //存儲修改之前的信號處理函數(shù) prehandler = signal(SIGINT, newhandler); if(prehandler == SIG_ERR) cerr<<"Error in signal"<<endl; /*現(xiàn)在,對于中斷信號的處理已經(jīng)修改為我們定義的newhandler函數(shù)*/ if(signal(SIGINT, prevhandler) == SIG_ERR) cerr<<"Error in signal"<<endl;
以上就是Linux signal()函數(shù)的使用學(xué)習(xí)的詳細內(nèi)容,更多關(guān)于Linux signal函數(shù)的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
使用shell檢查并修復(fù)mysql數(shù)據(jù)庫表的腳本
這篇文章主要介紹了使用shell檢查并修復(fù)mysql數(shù)據(jù)庫表的腳本,需要的朋友可以參考下2014-03-03shell腳本批量復(fù)制及執(zhí)行命令的示例詳解
這篇文章主要介紹了批量復(fù)制及執(zhí)行命令shell腳本,本文通過列舉幾個示例給大家詳細介紹,對大家的工作或?qū)W習(xí)具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03