日本免费全黄少妇一区二区三区-高清无码一区二区三区四区-欧美中文字幕日韩在线观看-国产福利诱惑在线网站-国产中文字幕一区在线-亚洲欧美精品日韩一区-久久国产精品国产精品国产-国产精久久久久久一区二区三区-欧美亚洲国产精品久久久久

Linux信號機制解析

在Linux中信號也稱為軟中斷,進程在收到信號之后在對信號進行處理,可以說就是一個中斷的過程 。本文就來為大家簡單地解析一下Linux信號機制 。

Linux信號機制解析


1、安裝信號處理函數(shù)
在系統(tǒng)編程的層面上與信號的處理關(guān)系最直接相關(guān)的函數(shù)有兩個,他們用來安裝信號處理函數(shù):
sighandler_t signal(int signum,sighandler_t handler);
int sigaction(int signum,const struct sigaction *act,,struct sigaction *oldact);
第一個函數(shù)signal比較簡單,sighandler_t 是一個別名,其原型是 typedef void (*sighandler_t)(int),他是一個函數(shù)指針,接受一個類型為int的參數(shù)(信號的編號),返回void 。例如要對SIGUSR1信號進行處理:
void handler(int sig)
{
//strsiganl 功能是把信號的編號轉(zhuǎn)為信號說明的字符串
printf(“Rcv a signal:%s”,strsignal(sig));
}
int main()
{
signal(SIGUSR1,handler);
while(1)
;
}
(這段程序其實是有問題的,后面會說到)這段程序本來是一段死循環(huán),但是對他發(fā)送SIGUSR1信號,程序會從while中“中斷”轉(zhuǎn)去執(zhí)行handler中的代碼 。在shell中使用kill命令發(fā)送信號SIGUSR1 于是程序就答應(yīng)出了一段這樣的信息:Rcv a signal:User defined signal 1 。signal()的用法幾乎就是這么簡單 。但是由于可移植的原因,參與項目開發(fā)時,應(yīng)該使用下面的這個函數(shù) 。
sigaction()函數(shù)的參數(shù)中有兩個結(jié)構(gòu)體,其man手冊原型如下:
struct sigaction {
void (*sa_handler)(int);
void (*sa_sigaction)(int,siginfo_t *,void *);
sigset_t sa_mask;
int sa_flags;
void (*sa_restorer)(void);
};
據(jù)我所知sa_handler和sa_sigaction其實是在一個union中,他們都是指向信號處理函數(shù)的指針 。
sa_mask 是要屏蔽的信號,sa_flags 有多種選項 。(關(guān)于這兩點后文再細(xì)說) 。從sigaction()原型中可以發(fā)現(xiàn)參數(shù)中有兩個struct sigaction參數(shù),其中act是要安裝的信號處理,而oldact是用來帶回原來的處理方式方便我們處理完信號后的恢復(fù) 。如果不需要拿回之前的信號處理方式可以把第三個參數(shù)置為NULL,反之如果只想得到之前的處理方式而不像安裝新的信號處理,可以把第二個參數(shù)置為NULL,這點用signal()是辦不到的 。用sigaction()改寫上面的例子是這樣的:
1 void handler(int sig)
2 {
3 printf(“Rcv a signal:%s”,strsignal(sig));
4 }
5
6 int main()
7 {
8 struct sigaction act;
9 sigemptyset(&act.sa_mask);
10 act.sa_handler = handler;
11 act.sa_flags = 0;
12 sigaction(SIGUSR1,&act,NULL);
13 while(1)
14 ;
【Linux信號機制解析】 15 }上一頁12下一頁 剩下全文

    推薦閱讀