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

桃源谷

心靈的旅行

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

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

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

鐵則4: 請不要做線程的異步撤消的設(shè)計(jì)

  • 線程的異步撤銷是指: 某個(gè)線程的執(zhí)行立刻被其他線程給強(qiáng)制終止了
  • 請不要單單為了讓“設(shè)計(jì)更簡單”或者“看起了更簡單”而使用線程的異步撤消

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

在pthread的規(guī)格說明中,允許一個(gè)線程可以強(qiáng)制中斷某個(gè)線程的執(zhí)行。這就是所說的異步撤消。


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

  • 方式1: 異步撤消(PTHREAD_CANCEL_ASYNCHRONOUS)
    • 撤銷動(dòng)作是馬上進(jìn)行的
  • 方式2: 延遲撤銷(PTHREAD_CANCEL_DEFERRED)
    • 撤消動(dòng)作,是讓線程的處理一直被延遲到撤消點(diǎn)才會(huì)去執(zhí)行

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


會(huì)造成什么問題呢

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

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

在這個(gè)例子中使用了malloc函數(shù),但是其他的危險(xiǎn)函數(shù)還有很多。


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


在這兒,參看規(guī)格(SUSv3)的話,會(huì)發(fā)現(xiàn),、描述異步撤消安全的函數(shù)只有3個(gè)

  1. pthread_cancel
  2. pthread_setcancelstate
  3. pthread_setcanceltype

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


如何避免這些問題呢

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


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


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

  • 在規(guī)格說明中只有3個(gè)異步撤消安全的函數(shù)
  • 這些以外的函數(shù)是不是異步撤消安全(商用UNIX)、因?yàn)闆]有說明文檔我們不清楚(Linux)

中有以上的兩點(diǎn),所以這個(gè)回避方法幾乎不現(xiàn)實(shí)。


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


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

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

有上面樣的問題、會(huì)導(dǎo)致「一精心設(shè)計(jì)撤消方式的替換,從一開始就使用延遲撤消還不夠好」這樣的結(jié)果。所以這幾乎是不好的一個(gè)回避策。


回避方法3: 使用pthread_cleanup_push函數(shù),登錄異步撤消時(shí)的線程數(shù)據(jù)清除的回調(diào)函數(shù)


第三種則是,用pthread_cleanup_push函數(shù)、登錄一個(gè)在異步撤消發(fā)生時(shí)的數(shù)據(jù)清除的回調(diào)函數(shù)。這和在準(zhǔn)則3中介紹的pthread_atfork函數(shù)有點(diǎn)兒類似。用這個(gè)函數(shù)登錄的回調(diào)函數(shù)來清除線程的數(shù)據(jù)和鎖,就可以回避死鎖了。


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


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


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

  • 設(shè)計(jì)成不依賴使用異步撤消那樣的處理

或者

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

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

*1:pthread_setcanceltype函數(shù)

*2:pthread_setcancelstate函數(shù)

*3:Solaris和HP-UX等

我的個(gè)人簡歷第一頁 我的個(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>
            久久美女性网| 亚洲一级二级在线| 欧美日韩无遮挡| 欧美精品一区二区在线观看| 欧美mv日韩mv亚洲| 欧美日韩一区在线| 国产精品久久久久久久7电影 | 亚洲综合成人婷婷小说| 亚洲视频一二区| 亚洲综合第一页| 欧美亚洲视频在线观看| 久久精品视频导航| 欧美粗暴jizz性欧美20| 欧美日韩综合在线| 国产日产欧美精品| 亚洲人成在线播放网站岛国| 亚洲欧美不卡| 老鸭窝91久久精品色噜噜导演| 欧美风情在线观看| 中文亚洲视频在线| 久久亚洲不卡| 国产精品啊啊啊| 亚洲午夜av在线| 午夜精品久久| 久久青草欧美一区二区三区| 亚洲三级视频| 午夜在线观看欧美| 欧美成人第一页| 国产精品乱人伦一区二区| 一区二区三区在线视频观看| 在线亚洲欧美专区二区| 麻豆精品一区二区综合av| 中国成人亚色综合网站| 免费在线观看日韩欧美| 国产亚洲在线| 亚洲欧美精品在线| 欧美激情精品久久久久久久变态| 亚洲视频国产视频| 欧美激情片在线观看| 含羞草久久爱69一区| 亚洲一区影音先锋| 最新日韩在线视频| 美女国产一区| 黄色成人在线网址| 久久精品毛片| 亚洲午夜精品久久久久久app| 欧美成人精品激情在线观看 | 一区二区三区自拍| 亚洲欧美文学| 一本色道久久综合亚洲91| 另类春色校园亚洲| 精品91免费| 久久精品国亚洲| 亚洲欧美成人网| 国产精品国产精品| 这里只有精品视频| 亚洲欧洲在线观看| 欧美不卡三区| 亚洲国产专区| 欧美成人免费全部观看天天性色| 欧美一区二区三区喷汁尤物| 国产精品亚洲网站| 欧美一区精品| 性色av一区二区三区| 国产视频一区三区| 久久综合一区| 免费视频一区二区三区在线观看| 韩日欧美一区| 欧美1级日本1级| 欧美成人免费在线观看| 在线视频中文亚洲| 亚洲天堂久久| 国产精品久久久久久久7电影| 亚洲欧美区自拍先锋| 亚洲女同性videos| 国产视频精品网| 久久综合久久美利坚合众国| 久久精品国产精品亚洲精品| 在线观看日韩av| 欧美电影资源| 欧美片在线播放| 欧美国产精品人人做人人爱| 国产精品日韩欧美综合| 久久久久.com| 免费观看一区| 亚洲一区国产视频| 欧美中文在线观看| 亚洲福利国产| 夜夜爽夜夜爽精品视频| 国产一区二区三区精品欧美日韩一区二区三区 | 欧美日韩中文字幕| 久久av红桃一区二区小说| 久久久www成人免费精品| 亚洲国产一区二区精品专区| 亚洲精品免费在线| 国产区欧美区日韩区| 欧美大片第1页| 国产精品xvideos88| 久热精品视频在线| 欧美日韩亚洲一区二区| 欧美在线免费视屏| 欧美国内亚洲| 久久精品视频亚洲| 欧美日韩国产成人| 麻豆91精品| 国产精品高潮粉嫩av| 六月婷婷一区| 国产精品美女久久久久久2018| 免费观看日韩| 国产精品视频一区二区三区| 亚洲国产日韩精品| 国自产拍偷拍福利精品免费一| 日韩视频免费大全中文字幕| 激情久久影院| 亚洲一区国产精品| 一级日韩一区在线观看| 久久综合999| 久久精品99国产精品| 欧美精品二区三区四区免费看视频| 欧美一区二区三区免费观看| 欧美国产日本| 欧美aaa级| 国产在线视频欧美| 亚洲一级在线| 亚洲视频中文| 欧美欧美在线| 亚洲电影在线看| 在线观看国产日韩| 欧美专区福利在线| 久久国产精品网站| 国产精品影音先锋| 99热免费精品| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 亚洲一区999| 亚洲一级电影| 欧美精品久久一区二区| 国产精品高清免费在线观看| 亚洲欧洲日本mm| 亚洲黄色尤物视频| 麻豆91精品91久久久的内涵| 久久只精品国产| 精品盗摄一区二区三区| 欧美影院视频| 久久久久天天天天| 黄色精品网站| 久久先锋影音| 亚洲丁香婷深爱综合| 亚洲美女精品久久| 欧美了一区在线观看| 日韩小视频在线观看专区| 中文精品99久久国产香蕉| 欧美精品在线一区二区| 亚洲免费观看高清在线观看| 一区二区三区四区五区视频| 欧美日韩一区精品| 午夜精品久久久久| 久久婷婷国产综合尤物精品| 怡红院精品视频| 男人插女人欧美| 亚洲精品一区二| 午夜精品理论片| 尤物yw午夜国产精品视频明星 | 蜜臀av性久久久久蜜臀aⅴ| 在线观看亚洲a| 欧美日韩精品欧美日韩精品一 | 牛牛精品成人免费视频| 亚洲片国产一区一级在线观看| 欧美日产一区二区三区在线观看 | 亚洲精品影院| 欧美一区二区三区四区高清 | 性久久久久久久久| 免费高清在线一区| 亚洲午夜在线观看| 国内精品久久久久久久影视蜜臀 | 亚洲国产精品va在看黑人| 免费久久精品视频| 一本色道久久综合亚洲精品婷婷 | 亚洲精品欧美极品| 欧美在现视频| 亚洲精品久久久久久久久久久| 欧美区二区三区| 欧美在线1区| 亚洲日本黄色| 久久理论片午夜琪琪电影网| 亚洲美女一区| 国产一区二区三区日韩| 欧美激情久久久久久| 香蕉亚洲视频| 欧美色图首页| 亚洲国产专区校园欧美| 欧美一级播放| 亚洲精品视频在线观看网站| 国产精品视频免费观看www| 免费国产一区二区| 性久久久久久| 亚洲婷婷免费| 亚洲美女精品久久| 免费亚洲婷婷| 久久精品国亚洲| 午夜精品视频在线观看|