亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java并發(fā)編程回環(huán)屏障CyclicBarrier

 更新時間:2022年04月15日 17:03:21   作者:派大大大星?  
這篇文章主要介紹了Java并發(fā)編程回環(huán)屏障CyclicBarrier,文章繼續(xù)上文所介紹的Java并發(fā)編程同步器CountDownLatch展開主題相關內(nèi)容,需要的小伙伴可以參考一下

CyclicBarrier

前面介紹的CountDownLatch在解決多個線程同步方面相對于調(diào)用線程的join方法已經(jīng)有了不少優(yōu)化。但是CountDownLatch的計數(shù)器是一次性的,也就是等到計數(shù)器值變?yōu)?后,再調(diào)用CountDownLatch的await和countdown方法都會立刻返回,這就起不到線程同步的效果了。所以為了滿足計數(shù)器可以重置的需要,JDK開發(fā)組提供了CyclicBarrier類,并且CyclicBarrier類的功能并不限于CountDownLatch的功能。從字面意思理解 CyclicBarrier 是回環(huán)屏障的意思,它可以讓一組線程全部達到一個狀態(tài)后再全部同時執(zhí)行。這里之所以叫作回環(huán)是因為當所有等待線程執(zhí)行完畢,并重置CyclicBarrier 的狀態(tài)后它可以被重用。之所以叫作屏障是因為線程調(diào)用await方法后就會被阻塞,這個阻塞點就稱為屏障點,等所有線程都調(diào)用了 await方法后,線程們就會沖破屏障,繼續(xù)向下運行。在介紹原理前先介紹幾個實例以便加深理解。在下面的例子中,我們要實現(xiàn)的是,使用兩個線程去執(zhí)行一個被分解的任務 A,當兩個線程把自己的任務都執(zhí)行完畢后再對它們的結果進行匯總處理。

import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class CycleBarrierTest {

   
   //創(chuàng)建一個線程數(shù)固定為2的線程池
   private static CyclicBarrier cyclicBarrier = new CyclicBarrier(2, new Runnable() {
       @Override
       public void run() {
           System.out.println(Thread.currentThread() + " task1 merge result");
       }
   });

   public static void main(String[] args) throws InterruptedException{
       ExecutorService executorService = Executors.newFixedThreadPool(2);

       
       //添加線程A到線程池
       executorService.submit(new Runnable() {
           @Override
           public void run() {
               try {
                   System.out.println(Thread.currentThread() + "task1");
                   System.out.println(Thread.currentThread() + "enter in  barrier");
                   cyclicBarrier.await();
                   System.out.println(Thread.currentThread() + "enter out  barrier");
               } catch (Exception e) {
                   e.printStackTrace();
               }
           }
       });

       //添加線程B到線程池
       executorService.submit(new Runnable() {
           @Override
           public void run() {
               try {
                   System.out.println(Thread.currentThread() + "task2");
                   System.out.println(Thread.currentThread() + "enter in  barrier");
                   cyclicBarrier.await();
                   System.out.println(Thread.currentThread() + "enter out  barrier");
               } catch (Exception e) {
                   e.printStackTrace();
               }
           }
       });

       //關閉線程池
       executorService.shutdown();

   }
}

image.png

如上代碼創(chuàng)建了一個CyclicBarrier對象,其第一個參數(shù)為計數(shù)器初始值,第二個數(shù)Runable是當計數(shù)值為0時需要執(zhí)行的任務。在main函數(shù)里面首先創(chuàng)建了一個大小為2的線程池。然后添加兩個子任務到線程池,每個子任務在執(zhí)行完自己的邏輯后會調(diào)用方法。一開始計數(shù)器值為2,當?shù)谝粋€線程調(diào)用await方法時,計數(shù)器值會遞減為1,由于此時計數(shù)器值不為0,所以當前線程就到了屏障點而被阻塞。然后第二個線程調(diào)用await時,會進入屏障,計數(shù)器值也會遞減,現(xiàn)在計數(shù)器值為0,這時就會去執(zhí)行 CyclicBarrier構造函數(shù)中的任務,執(zhí)行完畢后退出屏障點,并且喚醒被阻塞的第二個線程。這時候第一個線程也會退出屏障點繼續(xù)向下運行。

上面的例子說明了多個線程之間是相互等待的,假如計數(shù)器值為N,那么隨后調(diào)用 await 方法的N1個線程都會因為到達屏障點而被阻塞,當?shù)贜個線程調(diào)用await后,計數(shù)器值為0了,這時候第N個線程才會發(fā)出通知喚醒前面的N1個線程。也就是當全部線程都到達屏障點時才能一塊繼續(xù)向下執(zhí)行。對于這個例子來說,使用CountDownLatch也可以得到類似的輸出結果。下面再舉個例子來說明CyclicBarrier的可復用性。

假設一個任務由階段1、階段2和階段3組成,每個線程要串行地執(zhí)行階段1、階段2和階段3,當多個線程執(zhí)行該任務時,必須要保證所有線程的階段1全部完成后才能進入階段2執(zhí)行,當所有線程的階段2全部完成后才能進入階段3執(zhí)行。下面使用 CyclicBarrier 來完成這個需求。

import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class CycleBarrierTest1 {

    //創(chuàng)建一個線程數(shù)固定為2的線程池
    private static CyclicBarrier cyclicBarrier = new CyclicBarrier(2);

    public static void main(String[] args) throws InterruptedException{
        ExecutorService executorService = Executors.newFixedThreadPool(2);


        //添加線程A到線程池
        executorService.submit(new Runnable() {
            @Override
            public void run() {
                try {
                    System.out.println(Thread.currentThread() + "step1");
                    cyclicBarrier.await();
                    System.out.println(Thread.currentThread() + "step2");
                    cyclicBarrier.await();
                    System.out.println(Thread.currentThread() + "step3");
                    cyclicBarrier.await();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        });

        //添加線程B到線程池
        executorService.submit(new Runnable() {
            @Override
            public void run() {
                try {
                    System.out.println(Thread.currentThread() + "step1");
                    cyclicBarrier.await();
                    System.out.println(Thread.currentThread() + "step2");
                    cyclicBarrier.await();
                    System.out.println(Thread.currentThread() + "step3");
                    cyclicBarrier.await();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        });

        //關閉線程池
        executorService.shutdown();

    }
}

image.png

如上代碼中,每個子線程在執(zhí)行完階段1后都調(diào)用了await方法,等到所有線程都到達屏障點后才會一塊往下執(zhí)行,這就保證了所有線程都完成了階段1后才會開始執(zhí)行階段2。

到此這篇關于Java并發(fā)編程回環(huán)屏障CyclicBarrier的文章就介紹到這了,更多相關Java 回環(huán)屏障CyclicBarrier內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • SpringBoot項目從搭建到發(fā)布一條龍

    SpringBoot項目從搭建到發(fā)布一條龍

    這篇文章主要介紹了SpringBoot項目從搭建到發(fā)布一條龍,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • Spring框架 XML配置事務控制的步驟操作

    Spring框架 XML配置事務控制的步驟操作

    這篇文章主要介紹了Spring框架 XML配置事務控制的步驟操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • Java jdk安裝及javac命令無效解決方案

    Java jdk安裝及javac命令無效解決方案

    這篇文章主要介紹了Java jdk安裝及javac命令無效解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-12-12
  • Java常見面試題之多線程和高并發(fā)詳解

    Java常見面試題之多線程和高并發(fā)詳解

    這篇文章主要給大家介紹了關于Java面試題之多線程和高并發(fā)的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用java具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-04-04
  • Java關鍵詞final示例解讀

    Java關鍵詞final示例解讀

    這篇文章主要介紹了Java關鍵詞final解讀,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12
  • Java踩坑記錄之Arrays.AsList

    Java踩坑記錄之Arrays.AsList

    這篇文章主要給大家介紹了關于Java踩坑記錄之Arrays.AsList的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • Java 獲取當前設備的 IP 地址(最新推薦)

    Java 獲取當前設備的 IP 地址(最新推薦)

    Internet 協(xié)議 (IP) 地址可以是連接到 TCP/IP 網(wǎng)絡的每個設備的標識符,該標識符用于識別和定位中間通信的節(jié)點,這篇文章主要介紹了在 Java 中獲取當前設備的 IP 地址,需要的朋友可以參考下
    2023-06-06
  • 工廠方法模式_動力節(jié)點Java學院整理

    工廠方法模式_動力節(jié)點Java學院整理

    這篇文章主要介紹了工廠方法模式_動力節(jié)點Java學院整理的相關資料,需要的朋友可以參考下
    2017-08-08
  • Hibernate延遲加載技術詳解

    Hibernate延遲加載技術詳解

    這篇文章主要介紹了Hibernate延遲加載技術,結合實例形式詳細分析了Hibernate延遲加載所涉及的各種常用技巧,需要的朋友可以參考下
    2016-03-03
  • 解決java Graphics drawImage 無法顯示圖片的問題

    解決java Graphics drawImage 無法顯示圖片的問題

    這篇文章主要介紹了解決java Graphics drawImage 無法顯示圖片的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11

最新評論