一文詳解Java閉鎖和柵欄的實(shí)現(xiàn)
題目描述 -閉鎖
題目
有3個(gè)線程,線程A和線程B并行執(zhí)行,線程C需要和線程A和B執(zhí)行完成后才能執(zhí)行,使用閉鎖CountDownLatch實(shí)現(xiàn)
解題思路
創(chuàng)建一個(gè)類 :Abc Test
CountDownLatch初始化值為2
新增 A B線程,在線程里執(zhí)行邏輯后,計(jì)算-1
countDownLatch.countDown()
新增C線程,等待A,B線程來完成
countDownLatch.await();
執(zhí)行相關(guān)的邏輯
代碼詳解
AbcTest:
package cn.xiaoxuzhu.daily; import java.util.concurrent.CountDownLatch; public class AbcTest { public static void main(String[] args) { CountDownLatch countDownLatch =new CountDownLatch(2); //線程A new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(2000); }catch (InterruptedException e){ e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"線程A執(zhí)行結(jié)束"); countDownLatch.countDown(); } },"線程A").start(); //線程B new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(1000); }catch (InterruptedException e){ e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"線程B執(zhí)行結(jié)束"); countDownLatch.countDown(); } },"線程B").start(); new Thread(new Runnable() { @Override public void run() { try { countDownLatch.await(); }catch (InterruptedException e){ e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"線程C執(zhí)行結(jié)束"); countDownLatch.countDown(); } },"線程C").start(); } }
題目二描述 :柵欄
題目
有3個(gè)線程,線程A和線程B并發(fā)執(zhí)行,線程C需要A和B執(zhí)行完成后才能執(zhí)行。使用刪欄CyclicBarrier實(shí)現(xiàn)
解題思路
柵欄類似于閉鎖,它能阻塞一組線程直到某個(gè)事件發(fā)生。柵欄與閉鎖的關(guān)鍵區(qū)別在于,所有的線程
必須同時(shí)到達(dá)柵欄的位置,才能繼續(xù)執(zhí)行。
創(chuàng)建一個(gè)類:Abc Test2
CyclicBarrier初始化值為3
新增A,B線程,在線程里執(zhí)行完邏輯后,柵欄等待,符合三個(gè)線程都達(dá)到柵欄才往下執(zhí)行
cyclicBarrier.wait();
新增C線程,先柵欄等待,等A,B線程到達(dá)柵欄,就一起往下執(zhí)行
代碼詳解
package cn.xiaoxuzhu.daily; import java.util.concurrent.BrokenBarrierException; import java.util.concurrent.CyclicBarrier; /** * Description: 有3個(gè)線程。線程A和線程B并行執(zhí)行,線程C需要A和B執(zhí)行完成后才能執(zhí)行??梢栽趺磳?shí)現(xiàn)? * * @author 小王同學(xué) * @version 1.0 * @Description: */ public class AbcTest2 { public static void main(String[] args) { CyclicBarrier cyclicBarrier=new CyclicBarrier(3); //線程A new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(2000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"線程A執(zhí)行結(jié)束"); try { cyclicBarrier.await();//符合三個(gè)線程都到達(dá)柵欄才往下執(zhí)行 } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } },"線程A").start(); //線程B new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"線程B執(zhí)行結(jié)束"); try { cyclicBarrier.await();//符合三個(gè)線程都到達(dá)柵欄才往下執(zhí)行 } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } },"線程B").start(); //線程C new Thread(new Runnable() { @Override public void run() { //等待A,B線程完成 try { cyclicBarrier.await();//符合三個(gè)線程都到達(dá)柵欄才往下執(zhí)行 } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"線程C執(zhí)行結(jié)束"); } },"線程C").start(); } }
到此這篇關(guān)于一文詳解Java閉鎖和柵欄的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Java閉鎖 柵欄內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java實(shí)現(xiàn)更新順序表中的指定元素的示例
本文主要介紹了Java實(shí)現(xiàn)更新順序表中的指定元素的示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06java數(shù)據(jù)結(jié)構(gòu)之插入排序
這篇文章主要為大家詳細(xì)介紹了java數(shù)據(jù)結(jié)構(gòu)之插入排序的相關(guān)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11Java mysql數(shù)據(jù)庫(kù)并進(jìn)行內(nèi)容查詢實(shí)例代碼
這篇文章主要介紹了Java mysql數(shù)據(jù)庫(kù)并進(jìn)行內(nèi)容查詢實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2016-11-11JAVA設(shè)置手動(dòng)提交事務(wù),回滾事務(wù),提交事務(wù)的操作
這篇文章主要介紹了JAVA設(shè)置手動(dòng)提交事務(wù),回滾事務(wù),提交事務(wù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-04-04java讀取文件顯示進(jìn)度條的實(shí)現(xiàn)方法
當(dāng)讀取一個(gè)大文件時(shí),一時(shí)半會(huì)兒無法看到讀取結(jié)果,就需要顯示一個(gè)進(jìn)度條,是程序員明白已經(jīng)讀了多少文件,可以估算讀取還需要多少時(shí)間,下面的代碼可以實(shí)現(xiàn)這個(gè)功能2014-01-01Spring boot項(xiàng)目部署到云服務(wù)器小白教程詳解
這篇文章主要介紹了Spring boot項(xiàng)目部署到云服務(wù)器小白教程詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-04-04