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

飯中淹的避難所~~~~~

偶爾來避難的地方~

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  94 隨筆 :: 0 文章 :: 257 評論 :: 0 Trackbacks

volatile修飾,表示一個變量不進行寄存器優化,每次使用必須從內存中讀取。

在兩個線程間通信的時候,使用這個修飾,可以減少對鎖的依賴。這意味著降低死鎖的機會,提高效率。

我們假設存在兩個線程,A和B。我們在A和B之間建立兩條通道,A到B的通道和B到A的通道。

每個通道都有兩個狀態,當前有貨和當前沒貨。這個狀態用volatile來修飾,并確保它的寫操作是原子操作

我們先考慮A到B的通道,考慮通一個,另一個通道就反方向建立起來就可以了。

在A到B的通道中:
  - A來檢查通道的狀態,是否是當前沒貨。如果是,就把貨放到通道里,然后修改通道狀態為當前有貨。
  - B來檢查通道的狀態,是否是當前有貨。如果是,就把貨從通道里取出,然后修改通道狀態為當前沒貨。

以上兩個步驟因為是在A、B兩個線程內同步進行的,所以沒有標注順序號。


用上面的步驟,不論貨有多大,多么復雜。他們的讀寫操作都被這個修飾為volatile的狀態給限制在他們應該在的那個線程。

通過分析,我們總結出一個無鎖通信的結論:用volatile的狀態檢查和原子操作的狀態修改,隔離數據讀寫。

雖然現在只是在兩個線程間進行通信,不過這個結論,卻可以應用到多個線程同時參與的環境。


posted on 2010-05-05 19:42 飯中淹 閱讀(2334) 評論(11)  編輯 收藏 引用 所屬分類: 數據算法分析

評論

# re: 無鎖線程通信(1) 2010-05-05 20:25 shbooom
檢查,置位是兩個原子操作,所以還是不安全  回復  更多評論
  

# re: 無鎖線程通信(1) 2010-05-05 21:05 飯中淹
@shbooom
不會,這是絕對安全的。
檢查成功后,置位權就在自己手中了,所以不存在不安全的情況。
  回復  更多評論
  

# re: 無鎖線程通信(1) 2010-05-06 09:23 fcc
無鎖編程沒這么簡單吧?樓主你想象的情況太理想化了,A線程生產出來一個貨物,接下來B線程就消費一個貨物??墒钱斖ǖ乐幸呀浻胸涍€沒消費掉,A線程又生產出來了怎么辦?一、丟棄;二、等待B消費完當前貨物,然后放入通道中;三、讓通道貨物為一個容器,通道狀態依然在有貨狀態下A線程直接修改貨物容器。都是有問題的。方法一不適應絕大多數需求。方法二意味著低效。方法三意味著有可能兩個線程同時寫一個容器,絕對線程不安全。如果容器本身是線程安全的,那倒也行??墒侨萜魇蔷€程安全的意味著鎖在容器內部實現了,依然不是無鎖編程。以上是我的考慮,如有不周,請指教。  回復  更多評論
  

# re: 無鎖線程通信(1) 2010-05-06 10:32 飯中淹
@fcc
無鎖編程確實沒有這么簡單。
這個例子,你仔細看每一句話,其實說的是你第二種方法。也就是互相等待的方法。低效是肯定的。
這個是第一部分,從簡單的開始說起,慢慢的深入進去。
  回復  更多評論
  

# re: 無鎖線程通信(1) 2010-05-06 11:27 愛飯盒
不是低效的問題,是僅一個標識位不能做到同步,要做到同步,需要指令支持檢查置位做為一個原子操作。好像有cpu支持的。比如checkAndSet(flag)調用做為一個原子操作。否則就存在如下亂序。
if(A.check_flag() == 1 )
{
//線程A被掛起。
//線程B:if(B.check_flag() == 1) 此時也是為真,B.set_flag(0); 消耗掉資源,resource--;
//線程A被喚醒,
//線程A:A.set_flag(0);消耗資源. resource--;此時資源其實已經被消耗過了,A仍然可以去消耗。
//B.set_flag(1);
}
  回復  更多評論
  

# re: 無鎖線程通信(1) 2010-05-06 12:13 飯中淹
@愛飯盒
請你認真看清楚,我就不解釋了。  回復  更多評論
  

# re: 無鎖線程通信(1) 2010-05-06 12:21 陳昱(CY)
那個通道狀態“是否有貨”實際就是鎖,確實沒有同步起來  回復  更多評論
  

# re: 無鎖線程通信(1) 2010-05-06 12:33 小時候可靚了
嗯,這個方案還是可以滴。。
許多項目的源碼里也有用到。。
但他們同樣提供了帶鎖的方案。

估計這種簡單的無鎖有些局限,至于具體原因不知道。

先頂一個。希望你下一篇寫得更高深!  回復  更多評論
  

# re: 無鎖線程通信(1) 2010-05-06 12:49 bygreen
樓主最好實現個測試代碼,測試通過才行  回復  更多評論
  

# re: 無鎖線程通信(1)[未登錄] 2010-05-06 13:25 cppexplore
如果不考慮線程wait和signal的問題,僅僅是讀寫問題,不加鎖可行,我覺得前提是:
(1)只有兩個線程參與,存在point_r 讀指針和point_w 寫指針 兩個變量。
(2)只有讀數據線程 寫變量point_r , 只有寫數據線程 寫變量 point_w 。寫就是一個變量的寫操作只在一個線程內進行,其他線程只讀。

原子性操作不能借助語言層面的volatile實現,必須借助基于硬件的基本原語完成。最近常說的lock_free編程,具體實現是spin_lock,基于CAS原語實現,是因為沒有借助內核態的鎖而著稱。

  回復  更多評論
  

# re: 無鎖線程通信(1) 2010-05-06 15:13 飯中淹
@cppexplore
本篇文章序號(1)  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产日韩欧美在线99 | 猫咪成人在线观看| 在线一区二区三区四区五区| 欧美一级欧美一级在线播放| 一区二区三区精品| 美女福利精品视频| 久久久.com| 国产精品久久久久久久久久久久久| 欧美 日韩 国产 一区| 国产精品免费一区二区三区观看| 亚洲韩国青草视频| 91久久综合亚洲鲁鲁五月天| 久久久久久久国产| 久久er精品视频| 国产精品多人| 一区二区三区视频在线 | 亚洲免费网站| 欧美小视频在线| 亚洲风情亚aⅴ在线发布| 极品尤物av久久免费看| 欧美一区二区三区在线看| 欧美影院午夜播放| 国产视频精品va久久久久久| 亚洲欧美成人网| 亚洲欧美伊人| 国产精品日日摸夜夜摸av| 在线视频你懂得一区二区三区| 一区二区欧美日韩| 欧美日本国产一区| 亚洲精品中文字幕有码专区| 99re热这里只有精品免费视频| 蘑菇福利视频一区播放| 欧美高清视频www夜色资源网| 在线精品国精品国产尤物884a| 久久久久久噜噜噜久久久精品| 免费国产一区二区| 在线观看亚洲精品| 美日韩免费视频| 亚洲国产高清在线观看视频| 亚洲精品一区二区在线| 欧美日产一区二区三区在线观看 | 女主播福利一区| 亚洲精品视频啊美女在线直播| 欧美电影打屁股sp| 99热免费精品在线观看| 久久国产视频网站| 一区二区三区在线视频播放| 欧美成年人视频| 日韩视频专区| 久久精品国产69国产精品亚洲| 一区二区视频在线观看| 欧美成人免费全部| 一区二区三区四区五区精品视频| 午夜精品久久久久久久男人的天堂| 国产日韩欧美不卡| 免费在线国产精品| 一本色道久久88综合亚洲精品ⅰ| 久久av二区| 亚洲三级免费电影| 国产精品一区二区久久国产| 久久精品视频在线看| 亚洲精品系列| 久久影视精品| 在线亚洲观看| 亚洲第一区在线观看| 欧美日韩综合网| 久久视频这里只有精品| av成人毛片| 狼人天天伊人久久| 亚洲视频中文| 亚洲国产精品国自产拍av秋霞 | 伊人影院久久| 欧美性久久久| 美日韩丰满少妇在线观看| 亚洲一区二区在线观看视频| 欧美成人精品| 久久国产精品久久久| 亚洲国产精品一区二区尤物区| 国产精品成人免费精品自在线观看| 久久久99国产精品免费| 亚洲视频在线看| 亚洲高清不卡在线| 久久综合电影一区| 欧美一区二区在线视频| 99国产欧美久久久精品| 影音先锋中文字幕一区二区| 国产精品久久毛片a| 欧美另类女人| 猫咪成人在线观看| 久久久久久有精品国产| 欧美一级大片在线免费观看| 一区二区三欧美| 91久久精品美女| 欧美夫妇交换俱乐部在线观看| 久久久久国产精品一区| 欧美一区二区精美| 亚洲一区综合| 亚洲色图综合久久| 99在线热播精品免费99热| 在线欧美日韩精品| 国内精品久久久久伊人av| 国产精品一区免费观看| 欧美亚一区二区| 欧美日韩成人一区二区三区| 欧美国产日韩二区| 欧美成人激情在线| 免费高清在线视频一区·| 久久久久国产精品厨房| 久久精品国产亚洲精品| 欧美影视一区| 午夜精品av| 欧美一区日本一区韩国一区| 午夜欧美不卡精品aaaaa| 亚洲欧美电影院| 午夜精品短视频| 午夜视频在线观看一区二区| 亚洲欧美在线看| 欧美一级夜夜爽| 久久久久久成人| 免费看成人av| 欧美日韩国产专区| 国产精品久久久久久亚洲调教 | 久久久久99精品国产片| 久久久久久久91| 久久久夜精品| 欧美国产综合| 亚洲激情第一页| 一区二区免费在线观看| 亚洲欧美精品在线观看| 久久久7777| 欧美搞黄网站| 国产精品久久久91| 国产亚洲一区二区三区在线观看 | 久久天堂av综合合色| 欧美成人一区二区三区| 亚洲欧洲精品一区| 一本色道88久久加勒比精品| 亚洲图片在线| 久久综合九色综合欧美就去吻| 欧美激情国产精品| 国产精品久久久久免费a∨| 国产日韩精品一区观看| 亚洲第一伊人| 亚洲欧美另类在线| 免费美女久久99| 日韩五码在线| 久久久激情视频| 欧美少妇一区| 韩曰欧美视频免费观看| av72成人在线| 久久久久国内| 日韩西西人体444www| 久久av红桃一区二区小说| 麻豆精品一区二区综合av| 国产精品电影网站| 亚洲欧洲精品一区二区精品久久久 | 国产一区二区三区久久精品| 亚洲欧洲一区二区天堂久久| 亚洲欧美在线播放| 亚洲大胆人体在线| 香蕉久久夜色精品国产| 欧美另类69精品久久久久9999| 国产精品一区一区| 在线中文字幕一区| 免播放器亚洲| 亚洲欧美日韩区| 欧美色区777第一页| 亚洲国产精品久久久久秋霞蜜臀 | 亚洲第一级黄色片| 午夜一级久久| 亚洲欧洲在线看| 久久夜色精品亚洲噜噜国产mv| 国产精品麻豆欧美日韩ww| 亚洲乱码久久| 免费久久99精品国产自在现线| 亚洲欧美www| 国产精品红桃| 亚洲视频在线观看免费| 欧美高清在线| 久久久在线视频| 国产一区亚洲| 久久九九精品| 亚洲综合视频网| 国产精品日韩欧美| 亚洲综合色在线| 99精品欧美一区二区三区| 欧美高清在线视频| 亚洲人成小说网站色在线| 免费日韩av电影| 久久蜜桃av一区精品变态类天堂| 国产亚洲一区二区三区| 久久精品国产在热久久| 欧美伊久线香蕉线新在线| 国产欧美日韩另类视频免费观看| 香蕉久久夜色| 亚洲欧美在线磁力| 国内精品免费在线观看| 久久综合色综合88| 久久免费午夜影院| 亚洲国产mv|