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

桃源谷

心靈的旅行

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

準則4:請不要做線程的異步撤消的設計

Posted on 2008-12-19 11:01 lymons 閱讀(1309) 評論(0)  編輯 收藏 引用 所屬分類: C++CUnix/Linux文章翻譯
From 2008精選

原文地址:http://d.hatena.ne.jp/yupo5656/20040724/p1

[] UNIX上的C++程序設計守則 (4)Add star

鐵則4: 請不要做線程的異步撤消的設計

  • 線程的異步撤銷是指: 某個線程的執行立刻被其他線程給強制終止了
  • 請不要單單為了讓“設計更簡單”或者“看起了更簡單”而使用線程的異步撤消

咋一看還是挺簡單的。但是搞不好可能會引起各種各樣的問題。請不要在不能把握問題的實質就做出使用線程的異步撤消的設計!

在pthread的規格說明中,允許一個線程可以強制中斷某個線程的執行。這就是所說的異步撤消。


線程的撤消有下面的兩種方式。

  • 方式1: 異步撤消(PTHREAD_CANCEL_ASYNCHRONOUS)
    • 撤銷動作是馬上進行的
  • 方式2: 延遲撤銷(PTHREAD_CANCEL_DEFERRED)
    • 撤消動作,是讓線程的處理一直被延遲到撤消點才會去執行

還有,到底是用哪種撤消方式,不是撤消側,而是被撤銷側能夠決定的*1。另外,在被撤銷側也能夠選擇完全禁止撤消的這種方式 *2


會造成什么問題呢

那么,讓我看看亂用線程的異步撤消會引起什么問題呢。看過準則3的人可能會知道,在下面的腳本里,被撤銷線程以外的任意一個線程會被死鎖。

  1. 線程1中調用malloc函數正在做內存分配的過程中,線程2異步撤消了線程1的處理
  2. 線程1馬上被撤銷,但是malloc函數中的互斥鎖就沒有線程去解除了
  3. 后面的任意一個線程如果再次調用malloc函數的話就會馬上導致該線程死鎖

在這個例子中使用了malloc函數,但是其他的危險函數還有很多。


反之,即使做了異步撤消也沒有問題的函數也有少數存在的、我們把它們叫做「async-cancel safe函數」或者「異步撤消安全函數」。在一些商用UNIX*3中、OS提供的api函數的文檔說明中有async-cancel safety的記載、但是在Linux(glibc)里就很遺憾,幾乎沒有相關的說明。


在這兒,參看規格(SUSv3)的話,會發現,、描述異步撤消安全的函數只有3個

  1. pthread_cancel
  2. pthread_setcancelstate
  3. pthread_setcanceltype

而且、里面還有"No other functions are required to be async-cancel-safe"這樣的記載。因此,Linux的場合,如果在文檔里沒有記載成async-cancel safety的函數,我們還是把它假定成不安全的函數為好!


如何避免這些問題呢

在多線程編程中為了安全的使用異步撤消處理、有沒有回避死鎖的方法呢?我們試著想了幾個。他們與準則3里的線程+fork的場合的回避策很相似。


回避方法1: 被撤銷線程中,只能使用異步撤消安全函數


首先,被撤銷線程中,只能使用異步撤消安全函數。但是這個方法

  • 在規格說明中只有3個異步撤消安全的函數
  • 這些以外的函數是不是異步撤消安全(商用UNIX)、因為沒有說明文檔我們不清楚(Linux)

中有以上的兩點,所以這個回避方法幾乎不現實。


回避方法2: 被撤銷線程中,在做非異步撤消安全處理的過程中,再把撤消方式設置成「延遲」或者是「禁止」


第二個是,被撤銷線程在做非異步撤消安全處理的過程中,把撤消方式再設定成「延遲」或者「禁止」。對于這個方法

  • 就像方法1寫的那樣、要把我那個函數是異步撤消安全的一時還是挺麻煩的
  • 在任意的場所并不能保證撤消動作會被馬上執行
    • 例如,再設定成「延遲」后的一段時間內如果撤消發生時、某個正在阻塞的I/O函數是否能夠被解除阻塞還是挺微妙的
    • 如果設定成撤消禁止的話,則撤消會被屏蔽掉

有上面樣的問題、會導致「一精心設計撤消方式的替換,從一開始就使用延遲撤消還不夠好」這樣的結果。所以這幾乎是不好的一個回避策。


回避方法3: 使用pthread_cleanup_push函數,登錄異步撤消時的線程數據清除的回調函數


第三種則是,用pthread_cleanup_push函數、登錄一個在異步撤消發生時的數據清除的回調函數。這和在準則3中介紹的pthread_atfork函數有點兒類似。用這個函數登錄的回調函數來清除線程的數據和鎖,就可以回避死鎖了。


...但是,pthread_cleanup_push函數登錄的回調函數,在「延遲撤消」的場合是不能被調用的。因此、這個回避方法對于異步撤消沒有什么大的作用。


回避方法4: 不要執行異步撤消處理


最后是、不要執行異步撤消處理。反而代之的是、

  • 設計成不依賴使用異步撤消那樣的處理

或者

  • 不得不使用線程撤消的話、不做異步撤消而作延遲撤消的處理

這是比較實際的做法,是我們值得推薦的。

*1:pthread_setcanceltype函數

*2:pthread_setcancelstate函數

*3:Solaris和HP-UX等

我的個人簡歷第一頁 我的個人簡歷第二頁
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品久久久久一区二区三区| 亚洲美女av在线播放| 亚洲激情在线播放| 亚洲素人一区二区| 久久精品一二三区| 亚洲三级影院| 欧美亚洲视频一区二区| 欧美大片免费观看| 国产精品日韩专区| 亚洲激情视频在线播放| 午夜在线a亚洲v天堂网2018| 葵司免费一区二区三区四区五区| 亚洲激情在线播放| 欧美一级午夜免费电影| 欧美激情中文字幕在线| 国产夜色精品一区二区av| 一本色道久久综合狠狠躁的推荐| 久久精品国语| 亚洲乱码久久| 久久深夜福利免费观看| 国产精品久久久一本精品| 亚洲欧洲美洲综合色网| 欧美在线视频免费观看| 亚洲精品视频一区| 久久久久国产精品一区二区| 国产精品久久久久aaaa| 亚洲免费观看在线观看| 久久男人av资源网站| 中国亚洲黄色| 欧美高清在线播放| 在线免费不卡视频| 性色av香蕉一区二区| 亚洲人久久久| 美女精品自拍一二三四| 国产一区二区三区久久久久久久久 | 欧美一区日本一区韩国一区| 欧美人成在线视频| 亚洲国产高清在线观看视频| 久久成人精品无人区| 一区二区三区 在线观看视| 欧美成在线观看| 伊人激情综合| 久久亚洲精品一区二区| 亚洲欧美亚洲| 国产精品v片在线观看不卡| 在线免费观看日韩欧美| 久久免费少妇高潮久久精品99| 亚洲一区二区三区视频| 欧美丝袜一区二区| 一本大道av伊人久久综合| 欧美激情视频给我| 久久人人爽人人| 国语自产偷拍精品视频偷| 欧美一区二区三区免费大片| 中文欧美在线视频| 国产精品国产馆在线真实露脸| 亚洲视频综合在线| 99在线精品视频在线观看| 欧美精品亚洲| 日韩一区二区精品葵司在线| 亚洲国产精品久久久| 欧美成人精品一区二区| 亚洲免费观看高清在线观看| 亚洲激情一区二区三区| 欧美日本国产一区| 亚洲午夜三级在线| 在线亚洲+欧美+日本专区| 国产精品啊v在线| 亚洲欧美中文在线视频| 亚洲天堂网在线观看| 国产欧美激情| 久久亚洲国产成人| 久久女同互慰一区二区三区| 亚洲国产毛片完整版| 亚洲福利视频一区| 欧美精品性视频| 亚洲一区在线播放| 亚洲欧美一区在线| 韩国女主播一区| 欧美黄色网络| 欧美日韩在线影院| 午夜免费电影一区在线观看| 午夜视频一区二区| 在线观看一区| 91久久夜色精品国产九色| 欧美日韩大片| 午夜综合激情| 久久国产主播| 亚洲精品日韩在线| 日韩网站在线| 国产视频一区免费看| 嫩模写真一区二区三区三州| 欧美精品在线一区二区| 亚洲在线免费观看| 欧美一区在线直播| 亚洲免费成人av| 亚洲欧美日韩精品综合在线观看| 狠狠色2019综合网| 亚洲乱码国产乱码精品精可以看| 国产精品区一区二区三| 久久影院午夜论| 欧美理论片在线观看| 香蕉成人久久| 乱码第一页成人| 亚洲制服av| 久久精品亚洲| 一区二区三区福利| 久久福利资源站| 99国产精品久久久久久久| 性亚洲最疯狂xxxx高清| 亚洲欧洲日本在线| 亚洲欧美不卡| 亚洲精品国精品久久99热一| 国产精品99久久久久久白浆小说| 红桃视频一区| 夜夜精品视频一区二区| 一区二区三区中文在线观看| 99精品国产在热久久| 禁久久精品乱码| 一区二区精品国产| 亚洲福利av| 亚洲免费在线观看| 亚洲精选在线观看| 久久国产欧美精品| 亚洲香蕉网站| 美日韩精品视频免费看| 午夜在线a亚洲v天堂网2018| 蜜臀久久久99精品久久久久久| 亚洲欧美一区二区精品久久久| 免费高清在线一区| 欧美一区二区私人影院日本| 欧美国产综合视频| 久久网站热最新地址| 国产精品久久久久77777| 欧美激情成人在线视频| 国产色产综合产在线视频| 99精品久久| 亚洲三级影片| 久久久噜噜噜久久中文字幕色伊伊 | 一本一本久久a久久精品综合麻豆| 国产一区二区高清| 中文国产一区| 99精品99| 欧美a级片网| 久久艳片www.17c.com| 国产嫩草一区二区三区在线观看 | 亚洲一区二区精品在线| 麻豆成人综合网| 久久亚洲综合色一区二区三区| 国产精品美女久久久久久免费| 日韩视频永久免费| 亚洲人成网站在线播| 久久久九九九九| 久久精品国产2020观看福利| 欧美三级网址| 亚洲精品日韩激情在线电影| 亚洲激情视频网| 开心色5月久久精品| 快she精品国产999| 国产一区日韩二区欧美三区| 亚洲影院在线| 亚洲午夜一区| 欧美日韩午夜视频在线观看| 亚洲人成人一区二区三区| 亚洲欧洲日韩综合二区| 麻豆免费精品视频| 欧美91精品| 黄色精品一区| 久久人91精品久久久久久不卡| 久久人人爽人人爽爽久久| 国产一区二区黄色| 欧美有码视频| 久久婷婷国产麻豆91天堂| 国产一区二区无遮挡| 性高湖久久久久久久久| 久久久国产成人精品| 韩日视频一区| 久久久久国内| 欧美wwwwww| 亚洲国产精品久久| 欧美成人综合一区| 91久久久精品| 亚洲性感美女99在线| 欧美亚州一区二区三区 | 国产亚洲福利一区| 欧美专区福利在线| 欧美成人激情视频| 亚洲欧洲日产国产综合网| 欧美精品日韩一区| 夜夜嗨一区二区| 欧美在线视屏| 极品尤物久久久av免费看| 玖玖玖国产精品| 亚洲精品乱码久久久久久按摩观| 一本色道久久加勒比88综合 | 久久精品国产91精品亚洲| 国产主播一区二区三区四区| 久久人体大胆视频| 亚洲精品女人| 亚洲一区二区三区在线播放|