Java并發(fā)工具包——CyclicBarrier

Java并發(fā)工具包——CyclicBarrier

回顧

上一期Java并發(fā)工具包跟大家聊了下CountDownLatch,大家一定記得它的使用場景,那么這期繼續(xù)給大家說下Java并發(fā)工具中的常用工具——CyclicBarrier,這個工具類的使用場景跟CountDownLatch類似,下面跟大家展開說說。

簡介

通過類的名稱就可以了解一些

  • Cyclic——循環(huán)、回環(huán)
  • Barrier——柵欄、屏障

CyclicBarrier就是環(huán)形屏障,那么具體是什么意思呢?
很簡單,其實就是等待所有回環(huán)屏障中的線程都執(zhí)行到指定位置,才能夠繼續(xù)執(zhí)行。具體實際的例子就是遠途大巴車車滿發(fā)車。結(jié)合CountDownLatch來看的話就比較簡單了,CountDownLatch是若干線程等待所有工作的子線程,CyclicBarrier是若干線程等待,所有線程執(zhí)行完成之后,再繼續(xù)執(zhí)行,并且同實例可以重復(fù)使用,而且可以通過reset方法重置狀態(tài)(調(diào)用這個方法之后,執(zhí)行await的方法的地方會拋出BrokenBarrierException異常)。

應(yīng)用場景

  • 多線程計算數(shù)據(jù),最后統(tǒng)計核算各個線程的結(jié)果
  • 多線程業(yè)務(wù)中,同步節(jié)點(類似于JVM中垃圾回收章節(jié)的安全點概念)

例子

未使用回環(huán)屏障


使用回環(huán)屏障


重復(fù)使用回環(huán)屏障

實現(xiàn)原理

內(nèi)部實現(xiàn)類似與CountDownLatch,通過計數(shù)器來判斷是否繼續(xù)執(zhí)行,不過CyclicBarrier可以通過reset方法重置。所以CyclicBarrier能處理更為復(fù)雜的業(yè)務(wù)場景,一旦哪個線程計算中發(fā)生錯誤,可以通過重置計數(shù)器,并讓相關(guān)線程重新執(zhí)行。

源碼使用了ReentrantLock進行同步,如果達到最后的一個線程執(zhí)行await的話,那么index為0,會開始執(zhí)行barrierCommand的run方法。如果不是最后一個線程,就會進入循環(huán)等待的邏輯。

常見面試問題

  • 是否使用過CyclicBarrier?
  • CyclicBarrier的使用場景?
  • CyclicBarrier的常用方法?
  • 使用CyclicBarrier遇到過哪些問題,如何解決?
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容