歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux基礎 >> Linux技術

Linux信號機制解析

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

Linux信號機制解析

  1、安裝信號處理函數

  在系統編程的層面上與信號的處理關系最直接相關的函數有兩個,他們用來安裝信號處理函數:

  sighandler_t signal(int signum, sighandler_t handler);

  int sigaction(int signum, const struct sigaction *act,,struct sigaction *oldact);

  第一個函數signal比較簡單,sighandler_t 是一個別名,其原型是 typedef void (*sighandler_t)(int),他是一個函數指針,接受一個類型為int的參數(信號的編號),返回void。例如要對SIGUSR1信號進行處理:

  void handler(int sig)

  {

  //strsiganl 功能是把信號的編號轉為信號說明的字符串

  printf(“Rcv a signal:%s”,strsignal(sig));

  }

  int main()

  {

  signal(SIGUSR1,handler);

  while(1)

  ;

  }

  (這段程序其實是有問題的,後面會說到)這段程序本來是一段死循環,但是對他發送SIGUSR1信號,程序會從while中“中斷”轉去執行handler中的代碼。在shell中使用kill命令發送信號SIGUSR1 於是程序就答應出了一段這樣的信息:Rcv a signal:User defined signal 1。signal()的用法幾乎就是這麼簡單。但是由於可移植的原因,參與項目開發時,應該使用下面的這個函數。

  sigaction()函數的參數中有兩個結構體,其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);

  };

  據我所知sa_handler和sa_sigaction其實是在一個union中,他們都是指向信號處理函數的指針。

  sa_mask 是要屏蔽的信號,sa_flags 有多種選項。(關於這兩點後文再細說)。從sigaction()原型中可以發現參數中有兩個struct sigaction參數,其中act是要安裝的信號處理,而oldact是用來帶回原來的處理方式方便我們處理完信號後的恢復。如果不需要拿回之前的信號處理方式可以把第三個參數置為NULL,反之如果只想得到之前的處理方式而不像安裝新的信號處理,可以把第二個參數置為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 ;

  15 } 上一頁12下一頁共2頁

Copyright © Linux教程網 All Rights Reserved