Multi-Th:同步工具-柵欄

柵欄(Barrier)

通過閉鎖可以啟動(dòng)一組操作磨隘,或者等待一組操作結(jié)束脖隶。閉鎖是一次性對(duì)象油挥,一旦進(jìn)入結(jié)束狀態(tài)就不能被重置潦蝇。

柵欄類似于閉鎖,它能夠阻塞一組線程直到某個(gè)事件發(fā)生深寥。柵欄與閉鎖的關(guān)鍵區(qū)別在于攘乒,所有線程必須同時(shí)到達(dá)柵欄位置,才能繼續(xù)執(zhí)行惋鹅。 閉鎖用于等待事件则酝,柵欄用于等待其他線程。

CyclicBarrier

CyclicBarrier 可以使一定數(shù)量的參與方反復(fù)的在柵欄處匯集闰集。在迭代算法中非常有用(這類問題通常將一個(gè)問題拆分為成一系列相互獨(dú)立的子問題)當(dāng)線程到達(dá)柵欄時(shí)將調(diào)用 await() 方法沽讹,這個(gè)方法將阻塞直到所有的線程都到達(dá)柵欄的位置般卑。如果所有的線程都到達(dá)柵欄位置,那么柵欄將打開爽雄,所有的線程都會(huì)被釋放蝠检,而柵欄將會(huì)被重置以便下次使用。如果對(duì) await() 的調(diào)用超時(shí)挚瘟,或者 await() 阻塞的線程被中斷叹谁,那么柵欄就認(rèn)為是被打破了,所有的線程的 await() 調(diào)用都將終止并拋出 BrokenBarrierException乘盖。

線程成功的通過柵欄焰檩,那么 await() 將為每個(gè)線程返回一個(gè)唯一的到達(dá)索引號(hào),我們可以利用這些索引號(hào)來選舉產(chǎn)生一個(gè)領(lǐng)導(dǎo)線程订框,并在下次迭代中由該領(lǐng)導(dǎo)線程執(zhí)行一些特殊的工作析苫。

CyclicBarrier 還可以使你將一個(gè)柵欄操作傳遞給構(gòu)造函數(shù)(一個(gè)Runnable),當(dāng)成功通過柵欄時(shí)會(huì)在一個(gè)子任務(wù)線程中執(zhí)行它(在阻塞線程被釋放前是不能執(zhí)行的)

Exchanger

另一種形式的柵欄是 Exchanger布蔗,它是一種兩方柵欄藤违,各方在柵欄位置交換數(shù)據(jù)。

當(dāng)雙方執(zhí)行不對(duì)稱操作時(shí)纵揍,Exchanger 會(huì)比較好用顿乒。例如,當(dāng)一個(gè)線程向緩沖區(qū)寫入數(shù)據(jù)泽谨,而另一個(gè)線程從緩沖區(qū)讀取數(shù)據(jù)璧榄。這些線程就可以用 Exchanger 來匯合,并將滿的緩沖區(qū)與空的緩沖區(qū)交換吧雹。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末骨杂,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子雄卷,更是在濱河造成了極大的恐慌搓蚪,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,273評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件丁鹉,死亡現(xiàn)場(chǎng)離奇詭異妒潭,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)揣钦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門雳灾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人冯凹,你說我怎么就攤上這事谎亩。” “怎么了?”我有些...
    開封第一講書人閱讀 167,709評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵匈庭,是天一觀的道長夫凸。 經(jīng)常有香客問我,道長嚎花,這世上最難降的妖魔是什么寸痢? 我笑而不...
    開封第一講書人閱讀 59,520評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮紊选,結(jié)果婚禮上啼止,老公的妹妹穿的比我還像新娘。我一直安慰自己兵罢,他們只是感情好献烦,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著卖词,像睡著了一般巩那。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上此蜈,一...
    開封第一講書人閱讀 52,158評(píng)論 1 308
  • 那天即横,我揣著相機(jī)與錄音,去河邊找鬼裆赵。 笑死东囚,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的战授。 我是一名探鬼主播页藻,決...
    沈念sama閱讀 40,755評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼植兰!你這毒婦竟也來了份帐?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,660評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤楣导,失蹤者是張志新(化名)和其女友劉穎废境,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體筒繁,經(jīng)...
    沈念sama閱讀 46,203評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡彬坏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了膝晾。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,427評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡务冕,死狀恐怖血当,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤臊旭,帶...
    沈念sama閱讀 36,122評(píng)論 5 349
  • 正文 年R本政府宣布落恼,位于F島的核電站,受9級(jí)特大地震影響离熏,放射性物質(zhì)發(fā)生泄漏佳谦。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評(píng)論 3 333
  • 文/蒙蒙 一滋戳、第九天 我趴在偏房一處隱蔽的房頂上張望钻蔑。 院中可真熱鬧,春花似錦奸鸯、人聲如沸咪笑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽窗怒。三九已至,卻和暖如春蓄拣,著一層夾襖步出監(jiān)牢的瞬間扬虚,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評(píng)論 1 272
  • 我被黑心中介騙來泰國打工球恤, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留辜昵,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,808評(píng)論 3 376
  • 正文 我出身青樓碎捺,卻偏偏與公主長得像路鹰,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子收厨,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評(píng)論 2 359

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