青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Khan's Notebook GCC/GNU/Linux Delphi/Window Java/Anywhere

路漫漫,長修遠,我們不能沒有錢
隨筆 - 173, 文章 - 0, 評論 - 257, 引用 - 0
數據加載中……

防止信號處理失靈(轉載)

?  防止信號處理失靈
  
   作者:Danny Kalev
   編譯:MTT 工作室
  
   原文出處:Preventing Glitches in Signal Processing
  
  
   摘要:本文將剖析 ANSI <signal.h>庫并示范如何使用其接口。進而討論
   POSIX 信號處理 API。
  
  
   信號處理類似硬件中斷。它們促使某個進程從當前的執行控制流程中跳出,以實現特定的行為,待特定處理完成后,再恢復到中斷點繼續執行。本文將剖析
   ANSI <signal.h>庫并示范如何使用其接口。然后,本文將進而討論
   POSIX 信號處理 API。默認情況下,某些信號導致進程終止。例如,試圖存取進程不擁有的內存將觸發 SIGSEGV
   (“段故障”)信號,這時該信號會終止進程的執行。許多應用程序都有這個問題,這是我們不希望看到的。調試,仿真和事務處理系統必須處理這樣的信號以便讓進程繼續執行。那么我們如何防止這種發生呢?
   答案是安裝一個處理器處理進來的信號并在發生時捕獲它們
  
   第一步:建立信號處理器
  
   信號是內核傳給某個進程的一個整數。當進程接收到信號,它便以以下方式之一響應:
   忽略該信號;
   讓內核完成與該信號關聯的默認操作
   捕獲該信號,即讓內核將控制傳給信號處理例程,等信號處理例程執行完畢,然后又從中斷的地方恢復程序的執行。
  
  
   所謂信號處理例程是一個函數,當某個信號發生時,內核會自動調用該函數。signal()函數為給定的信號注冊一個處理例程:typedef void (*handler)(void);
  void * signal(int signum, handler);
   第一個參數是信號編碼。第二個參數用戶定義的函數地址,當信號 signum 產生時,handler 所指向的函數被調用。
   除了函數地址之外,第二個參數也可以是兩個特殊的值:SIG_IGN 和 SIG_DFL。SIG_IGN 表示該信號應被忽略(注意:SIGKILL
   和 SIGSTOP 在無論如何都是不能被阻塞、捕獲或忽略的);SIG_DFL 指示內核該信號產生時完成默認行為。
  
   第二步:發信號
  
   向某個進程發信號有三種方式:
   進程通過條用 raise() 顯式地發送信號給自己;
   信號從另一個進程發送,比方說通過
   kill() 系統調用或者
   Perl 腳本
   信號從內核發送。例如,當進程試圖存取不屬于自己的內存,或在系統關閉期間存取內存時;
  
   第三步:產生和處理信號
  
   下面程序注冊 SIGTERM 處理器。然后產生一個 SIGTERM 信號,從而導致該處理器運行:
   #include <csignal>
  #include <iostream>
  using namespace std;
  void term(int sig)
  {
  ? //..necessary cleanup operations before terminating
  ? cout << "handling signal no." <<sig <<endl;
  }
  int main()
  {
   signal(SIGTERM, term); // register a SIGTERM handler
   raise(SIGTERM); // will cause term() to run
  }
   ANSI <signal.h> 的局限
   當進入就緒狀態的某個進程準備運行一個 SIGx 信號處理例程時又接收到另一個 SIGx
   信號,這時會發生什么情況呢?一個方法是讓內核中斷該進程并再次運行該信號處理例程。為此,這個處理例程必須是可重入的(re-entrant)。但是,設計可重入的處理例程決非易事。ANSI
   C 解決重現信號(recurring signals)問題的方法是在執行用戶定義的處理例程前,將處理例程重置為 STG_DFL。這樣做是有問題的。
   當兩個信號快速產生時,內核運行第一個信號的處理例程,而對第二個信號則進行默認處理,這樣有可能終止該進程。
   在過去的三十年中出現了幾個可以信號處理框架,每一種框架對重現信號的處理問題提供了不同的解決方法。POSIX 信號 API
   是其中最為成熟的和可移植的一個。
  
   POSIX 信號
   POSIX 信號處理函數操作一組打包在 sigset_t 數據類型中信號:
   int sigemptyset(sigset_t * pset); 清除 pset 中的所有信號。
   int sigfillset(sigset_t * pset); 用可獲得的信號填充 pset。
   int sigaddset(sigset_t * pset, int signum); 將 signum 添加到 pset。
   int sigdelset(sigset_t * pset, int signum); 從 pset 中刪除 signum。
   int sigismember(const sigset_t * pset, int signum); 如果 signum 包含在
   pset 中,則返回非零,否則返回 0。
  
   Sigaction() 為特定的信號注冊處理例程:
   int sigaction(int signum, struct sigaction * act, struct sigaction *prev);
   sigaction 結構描述內核處理 signum 的信息:struct sigaction
  {
  ? sighanlder_t sa_hanlder;
  ? sigset_t sa_mask; // 阻塞信號的清單
  ? unsigned long sa_flags; // 阻塞模式
  ? void (*sa_restorer)(void); // 未使用
  };
   sa_hanlder 保存函數的地址,該函數帶一個整型參數,沒有返回值。它還可以是兩個特別值之一:SIG_DFL 和 SIG_IGN。
  
   額外特性
   POSIX API 提供多種 ANSI 庫中所沒有的服務。其中包括阻塞進入的信號并獲取當前未決信號。
  
  
   阻塞信號
   sigprocmask() 阻塞和取消阻塞信號:int sigprocmask(int mode, const sigset_t* newmask,sigset_t * oldmask);
   mode 可取以下值之一:
   SIG_BLOCK —— 將 newmask 中的信號添加到當前的信號擋板中。
   SIG_UNBLOCK —— 從當前的信號擋板中刪除 newmask 信號。
   SIG_SETMASK —— 僅阻塞 newmask 中的信號。
   獲取未決信號
   阻塞的信號處于等待狀態,直到進程就緒接收它們。這樣的信號被稱為未決信號,可以通過調用 sigpending() 來獲取。
   int sigpending(sigset_t * pset);
  
作者簡介
   Danny Kalev 是一名通過認證的系統分析師,專攻 C++ 和形式語言理論的軟件工程師。1997 年到 2000
   年期間,他是 C++ 標準委員會成員。最近他以優異成績完成了他在普通語言學研究方面的碩士論文。
   業余時間他喜歡聽古典音樂,閱讀維多利亞時期的文學作品,研究 Hittite、Basque 和 Irish Gaelic
   這樣的自然語言。其它興趣包括考古和地理。Danny 時常到一些 C++ 論壇并定期為不同的 C++
   網站和雜志撰寫文章。他還在教育機構講授程序設計語言和應用語言課程。

posted on 2006-09-28 09:55 Khan 閱讀(1241) 評論(0)  編輯 收藏 引用 所屬分類: GCC/G++跨平臺開發

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            在线免费不卡视频| 国产精品人人做人人爽| 午夜一区二区三区在线观看| 欧美大片va欧美在线播放| 亚洲日本欧美日韩高观看| 亚洲乱码久久| 欧美精品日韩三级| 久久成人亚洲| 国产精品三上| 亚洲国产老妈| 亚洲二区免费| 久久久久久伊人| 日韩视频一区二区三区| 亚洲校园激情| 亚洲风情在线资源站| 性欧美1819sex性高清| 亚洲图片欧洲图片av| 亚洲国产成人91精品| 91久久国产综合久久| 日韩午夜在线电影| 亚洲毛片一区| 亚洲午夜在线| 美女视频黄免费的久久| 欧美四级电影网站| 国语自产偷拍精品视频偷| 99精品视频免费全部在线| 久久蜜桃精品| 亚洲人成网在线播放| 久久激情视频| 黑人中文字幕一区二区三区| 国产日韩av高清| 国产在线不卡| 中文国产一区| 香蕉成人伊视频在线观看| 久久免费一区| 欧美一站二站| 精品成人在线| 一本色道久久综合一区| 国产免费亚洲高清| 伊人成年综合电影网| 久久天天躁狠狠躁夜夜爽蜜月| 久久麻豆一区二区| 久久综合伊人| 国产精品99一区| 国模私拍视频一区| 亚洲伊人一本大道中文字幕| 欧美激情精品久久久久久黑人| 亚洲一区二区三区视频| 欧美激情综合色综合啪啪| 国产在线拍偷自揄拍精品| 亚洲一区二区三区精品在线观看| 欧美sm重口味系列视频在线观看| 欧美一区二区三区视频免费| 国产精品久久久久影院色老大 | 欧美久久电影| 激情综合色丁香一区二区| 亚洲女ⅴideoshd黑人| 最新中文字幕一区二区三区| 久久久久久久久久久久久女国产乱| 国产精品裸体一区二区三区| 亚洲神马久久| 在线视频精品一| 国产精品久久久久国产精品日日 | 欧美日韩国产小视频在线观看| 亚洲成人原创| 老司机aⅴ在线精品导航| 午夜精品久久| 好吊妞这里只有精品| 久久久91精品国产| 欧美一区二区三区喷汁尤物| 韩日精品中文字幕| 欧美电影电视剧在线观看| 男女av一区三区二区色多| 91久久亚洲| 亚洲乱码国产乱码精品精98午夜| 欧美岛国激情| 一区二区欧美亚洲| 亚洲一区二区精品| 国产一区二区主播在线| 久久亚洲电影| 免费不卡在线观看av| 亚洲日本国产| 一区二区久久久久久| 国产日韩视频一区二区三区| 久久久另类综合| 免费成人网www| 狼人天天伊人久久| 久久婷婷色综合| 亚洲美女av电影| 亚洲精品日韩在线观看| 欧美日韩另类字幕中文| 欧美在线观看视频一区二区| 欧美在线一二三区| 99re6热在线精品视频播放速度| 99伊人成综合| 在线日本高清免费不卡| 亚洲美女黄色片| 国产亚洲欧美一级| 亚洲国产精品一区二区www| 国产精品激情| 欧美激情一区二区| 久久亚洲欧洲| 国产小视频国产精品| 午夜精品一区二区三区在线视| 欧美高清视频| 午夜精品久久久久久99热软件| 欧美视频观看一区| 在线日韩中文| 欧美日韩日本国产亚洲在线| 午夜精品免费在线| 在线亚洲自拍| 国产精品成人一区二区艾草| 亚洲美女色禁图| 欧美一区二区在线看| 欧美国产91| 亚洲图片欧美午夜| 精品999日本| 国产精品午夜在线| 欧美制服丝袜| 欧美在线综合| 欧美在线视频二区| 99视频精品免费观看| 久久久91精品国产| 久久久水蜜桃| 国产永久精品大片wwwapp| 欧美电影在线观看| 一本一本久久a久久精品牛牛影视| 亚洲在线网站| 久久人人超碰| 香蕉久久夜色精品| 欧美国产日韩一区二区| 亚洲嫩草精品久久| 亚洲影视九九影院在线观看| 久久不射网站| 亚洲欧美日韩精品久久| 99国内精品| 一区二区三区精品在线 | 亚洲一区在线看| 亚洲欧美日韩综合国产aⅴ| 亚洲国内精品在线| 国产精品视频不卡| 国产一区999| 久热这里只精品99re8久| 一区三区视频| 欧美激情中文不卡| 欧美日韩一区二区三区高清| 国产一区二区久久| 欧美在线亚洲一区| 久久亚洲一区二区| 裸体歌舞表演一区二区| 欧美精品国产精品| 久久久精品性| 欧美激情第3页| 亚洲摸下面视频| 久久成人18免费网站| 国产毛片久久| 99热这里只有精品8| 欧美在线亚洲综合一区| 99视频精品免费观看| 亚洲影院污污.| 亚洲日韩第九十九页| 美女亚洲精品| 欧美区一区二| 亚洲国产福利在线| 欧美精品一区二区三区蜜桃| 国产精品99久久99久久久二8| 黄色欧美成人| 久久视频在线看| 亚洲激情图片小说视频| 一区二区欧美日韩视频| 国产精品一区久久| 久久久久久尹人网香蕉| 亚洲人成网站精品片在线观看| 亚洲一区二区三区四区视频| 国产色综合网| 欧美高清视频| 欧美亚洲综合另类| 亚洲高清视频的网址| 亚洲免费在线| 亚洲国产免费| 国产视频一区在线观看一区免费| 欧美国产日产韩国视频| 香蕉久久国产| 一本久道久久综合婷婷鲸鱼| 久久久久国产精品人| 99riav久久精品riav| 国产在线不卡| 国产精品成人一区二区三区吃奶| 久久综合福利| 久久国产色av| 在线中文字幕日韩| 亚洲精品国产精品乱码不99 | 欧美日韩直播| 久久中文字幕一区| 性欧美xxxx大乳国产app| 亚洲精品永久免费精品| 免费高清在线视频一区·| 亚洲欧美视频在线观看| 日韩一本二本av| 亚洲国产欧美日韩精品|