天天看點

CyclicBarrier和CountDownLatch的差別

  • CountDownLatch是兩組線程,第一組負責計數器減一,第二組是阻塞線程,當第一組線程将計數器減到0時,第二組線程才開始執行,放行是由第三方控制;CyclicBarrier是隻有一組線程,隻有當所有線程到達攔截點的時候,才會繼續往下執行,放行是由一組線程本身控制。
  • CountDownLatch放行條件是大于或等于線程數;CyclicBarrier放行條件是等于線程數
  • CountDownLatch的計數器隻能使用一次,而CyclicBarrier的計數器可以使用reset()方法重 置。是以CyclicBarrier能處理更為複雜的業務場景。例如,如果計算發生錯誤,可以重置計數 器,并讓線程重新執行一次。
  • CyclicBarrier還提供其他有用的方法,比如getNumberWaiting方法可以獲得Cyclic-Barrier 阻塞的線程數量。isBroken()方法用來了解阻塞的線程是否被中斷。

參考

《java并發程式設計的藝術》

源碼