• <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>

            桃源谷

            心靈的旅行

            人生就是一場旅行,不在乎旅行的目的地,在乎的是沿途的風景和看風景的心情 !
            posts - 32, comments - 42, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            準則1:不依賴于信號收發的設計

            Posted on 2008-06-01 20:27 lymons 閱讀(1376) 評論(0)  編輯 收藏 引用 所屬分類: C++ 、C 、Unix/Linux文章翻譯
            From 2008精選

            [C++] UNIX上的C++程序設計守則(1)

            原文:http://d.hatena.ne.jp/yupo5656/20040712/p1

            Unix跟Windows等那些”對于開發者易于使用”的OS比起來,在信號和線程的利用方面有諸多的限制。但是即使不知道這些知識就做構架設計和實現的情況也隨處可見。這個就是那些經常不能再現的bug的溫床吧。

            因此,我想分成幾回來寫一些準則來防止陷入到這些圈套里。

            準則1:不依賴于信號收發的設計

            ·給其他進程以及自己發送異步信號并改變處理流程的設計不要做

            •  異步信號是值用kill系統調用來創建?發送的信號、例如SIGUSR1,SIGUSR2,SIGINT,SIGTERM 等
            • 簡單的使用忽略信號(SIG_IGN)則沒有問題

            ·不要把線程和信號一起使用 

            • 這將使程序動作的預測和調試變得很困難

             

            說明:

            同步信號是指,因為某些特定的操作*1而引起向自身進程發送某些特定的信號,例如SIGSEGV,SIGBUS,SIGPIPE,SIGSYS,SIGILL,SIGFPE。異步信號就是這些以外的信號。在什么時機發送異步信號并不能被預測出來。我們會在程序里追加收到某些信號時做一些特殊處理(信號處理函數)的函數。那么根據收到的信號就跳到信號處理函數的程序就叫做”在任意代碼處都能發生跳轉”的程序。這樣的程序往往隱藏這下面的那些問題:

            1. 容易引入BUG。”任意的代碼”雖然也包含”執行C/C++里面的一條語句的過程中”的意思,但這很容易跳出程序員的正常思維以及默認的假定條件。編寫程序的時候往往需要考慮比C++異常分支還要多得多的分支情況。
            2. 使測試項目激增。即使根據白盒測試達成100%的分支覆蓋,也不能網羅到因為接受信號而發生的跳轉分支處理。也就是說做到100%的網羅信號跳轉分支的測試是不能全部實現的。一般的,加上要考慮” 在實行某個特定代碼時因為接受到信號而發生的誤操作”這樣的BUG會經常發生*2的這種情況,測試困難往往就是導致軟件的品質低下的誘因。

             

            根據經驗,”當檢查到子進程結束(接收到SIGCHLD信號)時,要做必要的處理”像這樣的信號處理不管做什么都是有必要的情況會有,但是除此以外的信號處理,例如

            • 把自己的狀態用信號告訴其他進程
            • 主線程在輸入輸出函數里發送信號給被阻塞的子線程,并解除阻塞

            等,是應該事先好好好好考慮過后再去做實際的實現。前者的話,如果不強制在”普通的”進程間進行通信的話可能會很好,后者是特意要使用線程,也要應該按照即使阻塞了也不能發生問題那樣再設計。

            不管怎么樣,如果必須要使用信號的話,也要先全部*3理解這些陷阱以及,和多線程軟件設計的場合一樣或者說比它更嚴格的制約.注意事項都需要銘記在心里。

            *1:例如,引用空指針

            *2:參照 id:yupo5656:20040703 的sigsafe說明

            *3:暫時先掌握”準則2”:-)

            我的個人簡歷第一頁 我的個人簡歷第二頁
            国产亚洲精品自在久久| 亚洲?V乱码久久精品蜜桃 | 欧美久久天天综合香蕉伊| 久久精品天天中文字幕人妻| 久久综合久久美利坚合众国| 亚洲乱码日产精品a级毛片久久 | 思思久久精品在热线热| 伊人色综合九久久天天蜜桃| 日日狠狠久久偷偷色综合免费| 精品久久久久久无码人妻热| 久久99精品久久久久久秒播| 久久久久亚洲精品男人的天堂| 久久久久亚洲av毛片大| 青青青青久久精品国产h久久精品五福影院1421 | 99久久国产宗和精品1上映| 波多野结衣久久精品| 精产国品久久一二三产区区别 | 久久久久黑人强伦姧人妻| 久久国产成人午夜aⅴ影院| 久久WWW免费人成—看片| 免费精品久久久久久中文字幕| 国产精品成人久久久久久久| 久久精品国产72国产精福利| 久久亚洲国产精品123区| 青春久久| 国产精品免费福利久久| 国产精品成人99久久久久 | 久久久精品国产免大香伊| 久久精品国产亚洲AV嫖农村妇女 | 性做久久久久久久久久久| 蜜臀av性久久久久蜜臀aⅴ麻豆 | 久久妇女高潮几次MBA| 久久综合亚洲色一区二区三区| 久久精品a亚洲国产v高清不卡| 国产精品久久久久乳精品爆| 亚洲国产成人精品久久久国产成人一区二区三区综 | 狠狠色丁香久久综合婷婷| 久久精品免费大片国产大片| 亚洲AV无码1区2区久久| 狠狠久久亚洲欧美专区 | 亚洲午夜久久影院|