概述
sigaction(查詢或設定信號處理方式)相關函式 signal,sigprocmask,sigpending,sigsuspend, sigemptyset
表頭檔案 #include
定義函式 int sigaction(int signum,const struct sigaction *act ,struct sigaction *oldact);
函式說明 sigaction()會依參數signum指定的信號編號來設定該信號的處理函式。參數signum可以指定SIGKILL和SIGSTOP以外的所有信號。
如參數結構sigaction定義如下
struct sigaction {
union{
__sighandler_t sa_handler;
void (*_sa_sigaction)(int,struct siginfo *, void *);
}_u
sigset_t sa_mask;
unsigned long sa_flags;
void (*sa_restorer)(void);
}
信號處理函式可以採用void (*sa_handler)(int)或void (*sa_sigaction)(int, siginfo_t *, void *)。到底採用哪個要看sa_flags中是否設定了SA_SIGINFO位,如果設定了就採用void (*sa_sigaction)(int, siginfo_t *, void *),此時可以向處理函式傳送附加信息;默認情況下採用void (*sa_handler)(int),此時只能向處理函式傳送信號的數值。
sa_handler此參數和signal()的參數handler相同,代表新的信號處理函式,其他意義請參考signal()。
sa_mask 用來設定在處理該信號時暫時將sa_mask 指定的信號擱置。
sa_restorer 此參數沒有使用。
sa_flags 用來設定信號處理的其他相關操作,下列的數值可用。
sa_falgs還可以設定其他標誌:
SA_RESETHAND:當調用信號處理函式時,將信號的處理函式重置為預設值SIG_DFL
··SA_RESTART:如果信號中斷了進程的某個系統調用,則系統自動啟動該系統調用
SA_NODEFER :一般情況下, 當信號處理函式運行時,核心將阻塞該給定信號。但是如果設定了 SA_NODEFER標記, 那么在該信號處理函式運行時,核心將不會阻塞該信號
sigaction
示例
#includestatic void int_hander(int s)
{
printf("Catch a signal sigint\n");
}
int
main(void)
{
int i;
struct sigaction act, oact;
act. sa_handler = int_hander;
sigemptyset(∾t. sa_mask); //清空此信號集
act. sa_flags = 0;
sigaction(SIGINT, ∾t, &oact);
//signal(SIGINT, SIG_IGN);
while(1){
for(i=0; i<5; i++){
write(1, ".", 1);
sleep(1);
}
write(1, "\n", 1);
}
sigaction(SIGINT, &oact, NULL); //恢復成原始狀態
return 0;
}