欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一文詳解Java閉鎖和柵欄的實(shí)現(xiàn)

 更新時(shí)間:2022年06月14日 10:17:49   作者:學(xué)好c語言的小王同學(xué)  
閉鎖與柵欄是在多線程編程中的概念,因?yàn)樵诙嗑€程中,我們不能控制線程的執(zhí)行狀態(tài),所以給線程加鎖,讓其按照我們的想法有秩序的執(zhí)行。本文將詳解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)文章

最新評(píng)論