溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

循環(huán)柵欄CyclicBarrier舉例分析

發(fā)布時間:2021-12-14 15:15:05 來源:億速云 閱讀:106 作者:iii 欄目:大數(shù)據(jù)

本篇內容主要講解“循環(huán)柵欄CyclicBarrier舉例分析”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“循環(huán)柵欄CyclicBarrier舉例分析”吧!

循環(huán)柵欄CyclicBarrier,從英語字義可以理解為它是可以循環(huán)利用的,且柵欄是用來阻止線程在柵欄外等待的,它同樣是阻止線程等待,它和CountDownLatch倒底有什么區(qū)別呢?

給你出道題,5個線程同時執(zhí)行,當每個線程都執(zhí)行了某段代碼后再繼續(xù)往下執(zhí)行,如果5個線程未到齊,否則其他線程一直等待。

從上面的題目,我們來看下面的例子,理解什么是循環(huán)柵欄。

循環(huán)柵欄CyclicBarrier舉例分析

首先CyclicBarrier構造方法接受5個線程數(shù)和線程聚齊時的回調線程。什么意思呢?就是當5個線程都調用了await()方法,這5個線程才繼續(xù)往下執(zhí)行,執(zhí)行前先運行到齊時的回調線程。

從例子輸出的結果可以看出cb finish先運行的,說明到齊運行了回調線程,再輸出了每個線程的耗時,我們控制10個線程來阻塞等待,而循環(huán)柵欄只有5個,說明它是可以循環(huán)利用的,每到齊5個線程阻塞的線程就繼續(xù)執(zhí)行。

需要注意的await方法會拋出異常,一個是中斷異常InterruptedException,即是其他線程中斷了這個線程,另外一個是BrokenBarrierException,如果1個線程被打斷出現(xiàn)InterruptedException,其他等待在循環(huán)柵欄外面的線程就會出現(xiàn)BrokenBarrierException。因為一個線程被打斷了,即打破了循環(huán)柵欄的完整性,導致線程不能到齊其他線程永遠不能繼續(xù)執(zhí)行,這個異常也就避免了線程永遠等待的情況。

到此,相信大家對“循環(huán)柵欄CyclicBarrier舉例分析”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI