程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> C標准庫參考指南(9)signal.h

C標准庫參考指南(9)signal.h

編輯:關於C語言

9. signal.h

頭文件signal處理程序運行時產生的信號的方法。

宏:

SIG_DFL

SIG_ERR

SIG_IGN

SIGABRT

SIGFPE

SIGILL

SIGINT

SIGSEGV

SIGTERM

函數:

signal();

raise();

變量:

typedef sig_atomic_t

9.1. 變量和定義

類型sig_atomic_t就是int,作為signal函數的handler中的變量。SIG_宏用於signal函數中用於定義信號函數。

SIG_DFL   默認handler。

SIG_ERR   表示錯誤信號。

SIG_IGN   忽略信號。

SIG宏代表下列情況下的信號編號。

SIGABRT   異常終止(由abort函數產生)。

SIGFPE   浮點錯誤(由零除運行、不合理操作產生)。

SIGILL   非法操作(指令)。

SIGINT   交互信號(比如我們熟悉的Ctrl-C)。

SIGSEGV   非法存儲訪問(段錯誤,內存錯誤)。

SIGTERM   終止請求。

9.2. signal

聲明:

void (*signal(int sig, void (*func)(int)))(int);

該函數管理一個信號應該如何被操控。sig代表與SIG宏相容的信號編號。func函數會在信號產生時被調用。如果函數是SIG_DFL,則調用默認的handler。如果func是SIG_IGN,則信號被忽略。如果func指向一個函數,那麼當檢測到一個信號並執行默認handler時,該函數會被調用。函數必須攜帶一個int參數代表信號編號。函數可能被return,abort,exit,或者longjmp終止。當函數終止時,程序繼續從中斷處執行(除非是結果未定義的信號SIGFPE)。

如果信號調用成功,則返回指向之前特定信號類型的handler的指針。如果信號調用失敗,則返回SIG_ERR並且將errno設置一個合理值。

9.3. raise

聲明:

int raise(intsig);

產生sig信號。sig參數要與SIG宏兼容。

如果調用成功,會返回0。否則返回非零值。

實例:

#include<signal.h>   

#include<stdio.h>   


void catch_function(int);   


int main(void)   

{   

  if(signal(SIGINT, catch_function)==SIG_ERR)   

  {   

    printf("An error occured while setting a signal handler.\n");   

    exit(0);   

  }   


  printf("Raising the interactive attention signal.\n");   

  if(raise(SIGINT)!=0)   

  {   

    printf("Error raising the signal.\n");   

    exit(0);   

  }   

  printf("Exiting.\n");   

  return 0;   

}   


void catch_function(int signal)   

{   

  printf("Interactive attention signal caught.\n");   

}

程序運行輸出結果(假設沒有錯誤):

Raising the interactive attention signal.   

Interactive attention signal caught.

Exiting.

英文原文:http://www.acm.uiuc.edu/webmonkeys/book/c_guide/2.9.html

原文作者:Eric Huss

中文譯者:柳驚鴻 Poechant

版權聲明:本文的原文版權歸Eric Huss所有,中文譯文版權歸Poechant所有。轉載請注明來自"柳大的CSDN博客":http://blog.csdn.net/poechant

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved