您好,登錄后才能下訂單哦!
本篇文章和大家了解一下Linux中signal()函數怎么使用。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。
無意中看到了 signal() 函數,感覺對這個函數的原型有諸多疑惑,學習一下,順便分享。
Unix系統提供了signal()和sigaction()兩個函數來改變對于信號的處理方法。其中signal()是一個基于sigaction()系統調用的glibc庫函數,其行為在不同的Unix操作系統存在差異,對于可移植性有要求的程序不能使用signal()函數。
其原型如下:
#include<signal.h> void ( *signal(int sig, void (*handler)(int)) )(int);
signal函數的第一個參數sig,要傳入希望修改處理函數的信號編號,第二個參數,是一個無返回值、接受一個int形參的函數指針,指向對sig信號的新處理函數。函數的第二個參數可以有三種選擇,第一種是我們自己定義的信號處理函數,第二種是傳入SIG_DFL 表示將之前signal所改變的信號處理方式還原,第三種是傳入SIG_IGN,表示處理方式為忽略該信號,內核會直接將信號丟棄,不會傳遞到進程。
signal函數的返回值同樣是一個無返回值、接受一個int形參的函數指針。當signal()函數成功執行時,返回值是執行signal函數之前的sig信號的處理函數的指針,如果失敗,則返回SIG_ERR。
對信號處理函數指針做這樣的定義,可能便于理解:
//將sighandler_t定義為返回值為void,接受一個int形參的函數的指針 typedef void (*sighandler_t)(int); //現在我們可以這樣書寫signal函數 sighandler_t signal(int sig, sighandler_t handler);
其實glibc里已經有了如上的定義,只需要我們定義_GUN_SOURCE特性測試宏,就可以使用sighandler_t類型。
以下用法用于暫時性修改某信號的信號處理函數,在使用完之后,將信號處理函數重置為其原來版本。
void newhandler(int sig){ //code to handle the sig } void (*prevhandler)(int); //存儲修改之前的信號處理函數 prehandler = signal(SIGINT, newhandler); if(prehandler == SIG_ERR) cerr<<"Error in signal"<<endl; /*現在,對于中斷信號的處理已經修改為我們定義的newhandler函數*/ if(signal(SIGINT, prevhandler) == SIG_ERR) cerr<<"Error in signal"<<endl;
以上就是Linux中signal()函數怎么使用的簡略介紹,當然詳細使用上面的不同還得要大家自己使用過才領會。如果想了解更多,歡迎關注億速云行業資訊頻道哦!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。