happens-before偏序關(guān)系

  1. 判斷一個(gè)程序是不是存在數(shù)據(jù)競爭
    如果一個(gè)程序中存在兩個(gè)有沖突但不存在happens-before偏序關(guān)系的操作,則稱這個(gè)程序是存在數(shù)據(jù)競爭的询微。
    【案例1】假設(shè)r1r2是局部變量炫隶,AB是共享變量洞辣,則
Thread 1 Thread 2
1: r2 = A; 3: r1 = B;
2: B = 1; 4: A = 2;

由于

  • 操作1和操作4是存在沖突的,且不存在happens-before偏序關(guān)系码俩;
  • 操作2和操作3是存在沖突的度帮,且不存在happens-before偏序關(guān)系;

所以這個(gè)程序是存在數(shù)據(jù)競爭的稿存。

  1. 定義了一個(gè)happens-before一致性內(nèi)存模型
    對于被同步的共享變量笨篷,保證弱一致性,通過加內(nèi)存屏障(Memory Barrier)和緩存一致性協(xié)議實(shí)現(xiàn)瓣履,具體地講:
  • 讀volatile變量或者進(jìn)入鎖率翅,都會保證進(jìn)入一致性;
  • 寫volatile變量或者釋放鎖拂苹,都會保證釋放一致性安聘;
  • 同步變量的操作不允許進(jìn)行指令重排序,保證了其順序性瓢棒;

結(jié)合Pentium和PowerPC處理器中廣泛使用的一種主流的緩存一致性協(xié)議--MESI來解釋下浴韭。

假設(shè)CPU1執(zhí)行線程A,CPU2執(zhí)行線程B脯宿;CPU1和CPU2都有高速緩存念颈;線程A和線程B共享volatile變量started,

  • 當(dāng)CPU1從地址started=false讀取數(shù)據(jù)连霉,會廣播它的讀請求榴芳,如果沒有收到響應(yīng)嗡靡,即表明CPU1是最先開始讀取started的,然后將數(shù)據(jù)存入它的緩存并置為exclusive窟感;
  • 當(dāng)CPU2也從地址started讀取數(shù)據(jù)時(shí)讨彼,會廣播它的讀請求:CPU1在收到該讀請求后,檢測到地址沖突柿祈,將緩存中的拷貝狀態(tài)置為為shared哈误,作為響應(yīng);CPU2收到CPU1的響應(yīng)后躏嚎,將數(shù)據(jù)存入它的緩存并置為shared蜜自;
  • 當(dāng)CPU2寫started,即started=true時(shí)卢佣,將緩存中started狀態(tài)置為modified重荠,并廣播其寫請求;CPU1在收到請求后虚茶,將started的拷貝狀態(tài)置為Invalid戈鲁,作為響應(yīng);
  • 當(dāng)CPU1再從started讀取數(shù)據(jù)時(shí)媳危,會廣播它的讀請求荞彼;CPU2收到請求后冈敛,將started=true的數(shù)據(jù)發(fā)送到CPU1和刷新到主內(nèi)存待笑,設(shè)置started拷貝的狀態(tài)為shared,作為響應(yīng)抓谴;CPU1收到CPU2的響應(yīng)后暮蹂,將數(shù)據(jù)存入它的緩存并置為shared;

對于沒有被同步的共享變量癌压,

  • 只保證其正確性仰泻,即從單線程執(zhí)行的角度來說,程序的執(zhí)行結(jié)果和程序定義的結(jié)果是一致性的滩届;
  • 不保證其順序性集侯,因?yàn)闆]有數(shù)據(jù)相關(guān)性的代碼是可以重排序的;
  1. 判斷一個(gè)程序是不是被正確地同步了
    一個(gè)程序里的所有具有順序一致性的執(zhí)行都是無數(shù)據(jù)競爭的當(dāng)且僅當(dāng)這是一個(gè)被正確同步的程序帜消。
    根據(jù)上述定義棠枉,顯然有:
  • 如果一個(gè)程序被正確同步了,則就不需要考慮代碼重排因素對程序的影響了泡挺;
  • 正確同步一個(gè)程序可以用來防止由于代碼重排導(dǎo)致的違反直覺的執(zhí)行結(jié)果辈讶,但并不保證一個(gè)程序的正確性;
  • 如果一個(gè)程序被正確同步了娄猫,則程序員就可以以一種簡單的方式來考慮程序的執(zhí)行了贱除;
    具體的案例請參考:
    https://github.com/liyanghao/java-study/blob/master/src/concurrency/happens-before-examples.md

【參考資料】

  1. https://docs.oracle.com/javase/specs/jls/se7/html/jls-17.html#jls-17.4.5
  2. 《聊聊高并發(fā)(三十三)Java內(nèi)存模型那些事(一)從一致性(Consistency)的角度理解Java內(nèi)存模型》http://blog.csdn.net/iter_zc/article/details/41943387
  3. 《深入理解Java內(nèi)存模型(三)——順序一致性》http://www.infoq.com/cn/articles/java-memory-model-3
  4. 《為什么程序員需要關(guān)心順序一致性(Sequential Consistency)而不是Cache一致性(Cache Coherence生闲?)》
    http://www.infoq.com/cn/articles/java-memory-model-3
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市月幌,隨后出現(xiàn)的幾起案子碍讯,更是在濱河造成了極大的恐慌,老刑警劉巖扯躺,帶你破解...
    沈念sama閱讀 211,743評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件冲茸,死亡現(xiàn)場離奇詭異,居然都是意外死亡缅帘,警方通過查閱死者的電腦和手機(jī)轴术,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,296評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來钦无,“玉大人逗栽,你說我怎么就攤上這事∈г荩” “怎么了彼宠?”我有些...
    開封第一講書人閱讀 157,285評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長弟塞。 經(jīng)常有香客問我凭峡,道長,這世上最難降的妖魔是什么决记? 我笑而不...
    開封第一講書人閱讀 56,485評論 1 283
  • 正文 為了忘掉前任摧冀,我火速辦了婚禮,結(jié)果婚禮上系宫,老公的妹妹穿的比我還像新娘索昂。我一直安慰自己,他們只是感情好扩借,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,581評論 6 386
  • 文/花漫 我一把揭開白布椒惨。 她就那樣靜靜地躺著,像睡著了一般潮罪。 火紅的嫁衣襯著肌膚如雪康谆。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,821評論 1 290
  • 那天嫉到,我揣著相機(jī)與錄音沃暗,去河邊找鬼。 笑死屯碴,一個(gè)胖子當(dāng)著我的面吹牛描睦,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播导而,決...
    沈念sama閱讀 38,960評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼忱叭,長吁一口氣:“原來是場噩夢啊……” “哼隔崎!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起韵丑,我...
    開封第一講書人閱讀 37,719評論 0 266
  • 序言:老撾萬榮一對情侶失蹤爵卒,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后撵彻,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體钓株,經(jīng)...
    沈念sama閱讀 44,186評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,516評論 2 327
  • 正文 我和宋清朗相戀三年陌僵,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了轴合。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,650評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡碗短,死狀恐怖受葛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情偎谁,我是刑警寧澤总滩,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站巡雨,受9級特大地震影響闰渔,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜铐望,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,936評論 3 313
  • 文/蒙蒙 一冈涧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蝌以,春花似錦炕舵、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,757評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽溶推。三九已至徊件,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蒜危,已是汗流浹背虱痕。 一陣腳步聲響...
    開封第一講書人閱讀 31,991評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留辐赞,地道東北人部翘。 一個(gè)月前我還...
    沈念sama閱讀 46,370評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像响委,于是被迫代替她去往敵國和親新思。 傳聞我的和親對象是個(gè)殘疾皇子窖梁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,527評論 2 349

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)夹囚,斷路器纵刘,智...
    卡卡羅2017閱讀 134,633評論 18 139
  • 從三月份找實(shí)習(xí)到現(xiàn)在,面了一些公司荸哟,掛了不少假哎,但最終還是拿到小米、百度鞍历、阿里舵抹、京東、新浪劣砍、CVTE掏父、樂視家的研發(fā)崗...
    時(shí)芥藍(lán)閱讀 42,213評論 11 349
  • 原創(chuàng)文章&經(jīng)驗(yàn)總結(jié)&從校招到A廠一路陽光一路滄桑 詳情請戳www.codercc.com # 1. JMM的介紹 ...
    你聽___閱讀 39,530評論 12 116
  • 我們小區(qū)有位坐輪椅的老奶奶,無論刮風(fēng)下雨秆剪,總能在小區(qū)樓下看到她的身影赊淑。 天氣好時(shí),老奶奶就起身扶著輪椅慢慢走...
    吳艾嘉閱讀 365評論 0 0
  • 劉晴的求救電話 劉叔劉嬸簡單的收拾了下外屋仅讽,我和他們一家三口坐到了一張桌子旁陶缺。 我受的全是外傷,因?yàn)樽孕【毴木壒?..
    93f1bf1c7d4f閱讀 315評論 0 3