一文詳解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線程來(lái)完成
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 內(nèi)置Http Server構(gòu)建web應(yīng)用案例詳解
這篇文章主要介紹了Java 內(nèi)置Http Server構(gòu)建web應(yīng)用案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
一行命令同時(shí)修改maven項(xiàng)目中多個(gè)module的版本號(hào)的方法
這篇文章主要介紹了一行命令同時(shí)修改maven項(xiàng)目中多個(gè)module的版本號(hào)的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-06-06
解決springboot mapper注入報(bào)紅問(wèn)題
這篇文章主要介紹了解決springboot mapper注入報(bào)紅問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11
Netty啟動(dòng)流程服務(wù)端channel初始化源碼分析
這篇文章主要為大家介紹了Netty啟動(dòng)流程服務(wù)端channel初始化源碼分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-03-03
解決Spring?Security集成knife4j訪問(wèn)接口文檔出現(xiàn)403的問(wèn)題
這篇文章主要給大家介紹了如何解決Spring?Security集成knife4j訪問(wèn)接口文檔出現(xiàn)403的問(wèn)題,文中有詳細(xì)的解決方案,有需要的朋友可以參考閱讀下2023-07-07
SpringBoot分頁(yè)查詢功能的實(shí)現(xiàn)方法
在實(shí)際的項(xiàng)目開發(fā)過(guò)程中,分頁(yè)顯示是很常見(jiàn)的頁(yè)面布局,所以學(xué)習(xí)如何實(shí)現(xiàn)分頁(yè)也是必要的,下面這篇文章主要給大家介紹了關(guān)于SpringBoot分頁(yè)查詢功能的實(shí)現(xiàn)方法,需要的朋友可以參考下2022-06-06
JAVA-4NIO之Channel之間的數(shù)據(jù)傳輸方法
下面小編就為大家?guī)?lái)一篇JAVA-4NIO之Channel之間的數(shù)據(jù)傳輸方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06
java中Lambda常用場(chǎng)景代碼實(shí)例
這篇文章主要介紹了java中Lambda常用場(chǎng)景,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
SpringBoot實(shí)現(xiàn)服務(wù)接入nacos注冊(cè)中心流程詳解
這篇文章主要介紹了SpringBoot實(shí)現(xiàn)服務(wù)接入nacos注冊(cè)中心流程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2023-01-01

