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

桃源谷

心靈的旅行

人生就是一場旅行,不在乎旅行的目的地,在乎的是沿途的風景和看風景的心情 !
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>
            欧美电影免费| 日韩视频不卡中文| 久久精品女人| 影音先锋久久久| 欧美波霸影院| 欧美h视频在线| 亚洲天堂av在线免费| 一本色道久久综合狠狠躁篇的优点| 欧美日韩国产限制| 亚洲一区免费观看| 欧美亚洲一级片| 亚洲国产精品999| 亚洲精品日韩久久| 国产精品入口尤物| 久久久午夜视频| 欧美成人免费播放| 亚洲欧美综合v| 久久久999国产| 一卡二卡3卡四卡高清精品视频| 一区二区高清在线| 国产一区二区在线观看免费播放| 久久久久国产精品一区三寸| 蜜乳av另类精品一区二区| 99综合电影在线视频| 午夜精品久久久久久久久久久 | 日韩香蕉视频| 国产精品一二一区| 麻豆成人在线播放| 国产精品久久精品日日| 免费成年人欧美视频| 欧美色欧美亚洲高清在线视频| 久久精品亚洲| 欧美精品一区二区三区在线播放| 午夜在线观看免费一区| 另类激情亚洲| 久久国产免费看| 欧美美女bb生活片| 久久久久国产精品一区三寸| 欧美日韩一级视频| 裸体素人女欧美日韩| 欧美视频中文字幕| 欧美国产视频在线观看| 国产精品一区二区男女羞羞无遮挡 | 国产精品综合久久久| 欧美福利视频网站| 国产亚洲精品v| 一区二区av在线| 亚洲精品一区中文| 久久精品国产久精国产爱 | 国产伦理一区| 日韩视频在线你懂得| 激情校园亚洲| 久久久国际精品| 欧美在线不卡| 国产精品video| 日韩网站在线| 在线亚洲免费视频| 欧美精品国产精品| 亚洲国产成人午夜在线一区| 好看的日韩视频| 亚洲在线观看视频| 小黄鸭精品aⅴ导航网站入口| 欧美久久电影| 99精品99| 亚洲——在线| 国产精品一区2区| 亚洲一二三区在线观看| 亚洲午夜一区二区| 欧美色视频一区| 亚洲一区二区欧美| 久久国产精品久久久| 国产精品最新自拍| 亚洲一区高清| 久久精品视频免费| 国产一区日韩一区| 久久久久国产成人精品亚洲午夜| 久久电影一区| 韩国女主播一区| 久久婷婷国产综合国色天香| 欧美xx69| 99精品欧美一区二区三区| 欧美喷水视频| 亚洲天堂激情| 欧美一区二区三区在线免费观看| 国产一区二区电影在线观看| 久久国产66| 亚洲国产精品久久久久秋霞蜜臀| 日韩性生活视频| 欧美午夜一区二区| 欧美一区二视频| 免费亚洲视频| 亚洲小视频在线观看| 国产精品久久久久国产a级| 亚洲已满18点击进入久久| 久久久久久色| 一本色道久久综合狠狠躁篇的优点| 国产精品sss| 欧美专区日韩专区| 亚洲国产精品一区二区三区| 国产精品99久久99久久久二8| 国产精品国产三级国产专区53| 亚洲欧美日韩视频一区| 欧美电影在线观看完整版| 亚洲一区国产视频| 在线观看日韩av先锋影音电影院 | 一本一道久久综合狠狠老精东影业 | 99re6热只有精品免费观看| 久久福利影视| 99re在线精品| 好吊妞**欧美| 国产精品久久久久久久第一福利| 久久精品成人一区二区三区 | 欧美一区午夜精品| 亚洲国产精彩中文乱码av在线播放| 欧美日韩视频在线第一区| 久久久久久久久综合| 正在播放欧美一区| 欧美高清不卡在线| 久久黄色影院| 亚洲一区影院| 亚洲精品中文字幕在线观看| 国产一区在线播放| 国产精品成人午夜| 女人色偷偷aa久久天堂| 午夜精品一区二区三区在线| 亚洲精品护士| 欧美大片在线观看| 久久人人97超碰精品888| 亚洲一区二区三区在线视频| 亚洲国产中文字幕在线观看| 国产午夜一区二区三区| 国产精品成人一区二区艾草| 欧美成人午夜77777| 久久久久综合一区二区三区| 欧美一区二区视频97| 亚洲午夜激情在线| 中文高清一区| 亚洲美女淫视频| 亚洲欧洲日韩女同| 亚洲国产欧美不卡在线观看| 免费观看成人| 免费视频一区二区三区在线观看| 久久久久久久久久久久久久一区 | 亚洲图片欧美午夜| 亚洲精品午夜精品| 91久久久在线| 亚洲精品黄色| 一区二区三区高清| 一区二区三区毛片| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲伊人一本大道中文字幕| 亚洲小视频在线观看| 一区二区三区高清在线观看| 亚洲美女视频网| 中文欧美字幕免费| 亚洲一区制服诱惑| 西西人体一区二区| 久久激五月天综合精品| 久久久久久九九九九| 久久综合中文| 欧美第一黄网免费网站| 欧美理论在线播放| 国产精品区一区二区三区| 国产日韩欧美成人| 精品999在线播放| 亚洲品质自拍| 亚洲一区二区三区在线视频| 欧美在线一二三四区| 久热精品视频在线观看一区| 亚洲第一中文字幕| 一本色道88久久加勒比精品 | 蜜臀久久久99精品久久久久久| 欧美大片在线看免费观看| 亚洲国产欧美在线 | 久久成人精品一区二区三区| 久久亚洲一区| 亚洲区免费影片| 亚洲欧美日韩中文在线制服| 久久香蕉精品| 欧美视频中文字幕| 伊人久久亚洲影院| 亚洲网站在线| 两个人的视频www国产精品| 亚洲欧洲一区二区在线观看| 亚洲天堂黄色| 欧美aa在线视频| 国产女人18毛片水18精品| 亚洲风情在线资源站| 亚洲摸下面视频| 欧美成人日韩| 亚洲综合色自拍一区| 免费看的黄色欧美网站| 国产精品视频一| 亚洲剧情一区二区| 久久久九九九九| 亚洲每日更新| 老司机精品视频一区二区三区| 欧美日韩精品久久| 国模叶桐国产精品一区| 亚洲一区三区视频在线观看|