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

SpringBoot CountDownLatch多任務(wù)并行處理的實現(xiàn)方法

 更新時間:2018年04月22日 15:36:52   作者:小柒  
本篇文章主要介紹了SpringBoot CountDownLatch多任務(wù)并行處理的實現(xiàn)方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言

最近在做一個原始成績統(tǒng)計的功能,用戶通過前臺設(shè)置相關(guān)參數(shù),后臺實時統(tǒng)計并返回數(shù)據(jù)。相對來說統(tǒng)計功能點還是比較多的,這里大體羅列一下。

  1. 個人排名
  2. 本次測試的優(yōu)良線、及格線、低分線
  3. 各個班級的排名人數(shù)(1-25、26-50 類比等等)
  4. 各個班級的前X名人數(shù)統(tǒng)計(前10、前20 類比等等)
  5. 各個班級的分?jǐn)?shù)段學(xué)生人數(shù)統(tǒng)計(150-140、139-130 類比等等)

最好的用戶體驗,就是每一個操作都可以實時的展示數(shù)據(jù),3秒之內(nèi)應(yīng)該是用戶的忍受范圍之內(nèi)的了,所以做一款產(chǎn)品不僅要考慮用戶交互設(shè)計,后端的優(yōu)化也是比不可少的。

大家可以簡單的看下以上這5項統(tǒng)計數(shù)據(jù),總體來說,統(tǒng)計量還是不少的。最主要的還是要實時、實時、實時(重要的事情說三遍),顯然定時任務(wù)是不現(xiàn)實的。

改造前

程序邏輯

順序執(zhí)行任務(wù).png

改造后

程序邏輯


多任務(wù)并行處理.png

多任務(wù)并行處理,適用于多核CPU,單核CPU多線程執(zhí)行任務(wù)可能會適得其反(上下文切換以及線程的創(chuàng)建和銷毀都會消耗資源),特別是CPU密集型的任務(wù)。

代碼實現(xiàn)

StatsDemo偽代碼:

/**
 * 多任務(wù)并行統(tǒng)計
 * 創(chuàng)建者 科幫網(wǎng)
 * 創(chuàng)建時間  2018年4月16日
 */
public class StatsDemo {
  final static SimpleDateFormat sdf = new SimpleDateFormat(
      "yyyy-MM-dd HH:mm:ss");
  
  final static String startTime = sdf.format(new Date());

  public static void main(String[] args) throws InterruptedException {
    CountDownLatch latch = new CountDownLatch(5);// 兩個賽跑者
    Stats stats1 = new Stats("任務(wù)A", 1000, latch);
    Stats stats2 = new Stats("任務(wù)B", 2000, latch);
    Stats stats3 = new Stats("任務(wù)C", 2000, latch);
    Stats stats4 = new Stats("任務(wù)D", 2000, latch);
    Stats stats5 = new Stats("任務(wù)E", 2000, latch);
    stats1.start();//任務(wù)A開始執(zhí)行
    stats2.start();//任務(wù)B開始執(zhí)行
    stats3.start();//任務(wù)C開始執(zhí)行
    stats4.start();//任務(wù)D開始執(zhí)行
    stats5.start();//任務(wù)E開始執(zhí)行
    latch.await();// 等待所有人任務(wù)結(jié)束
    System.out.println("所有的統(tǒng)計任務(wù)執(zhí)行完成:" + sdf.format(new Date()));
  }

  static class Stats extends Thread {
    String statsName;
    int runTime;
    CountDownLatch latch;

    public Stats(String statsName, int runTime, CountDownLatch latch) {
      this.statsName = statsName;
      this.runTime = runTime;
      this.latch = latch;
    }

    public void run() {
      try {
        System.out.println(statsName+ " do stats begin at "+ startTime);
        //模擬任務(wù)執(zhí)行時間
        Thread.sleep(runTime);
        System.out.println(statsName + " do stats complete at "+ sdf.format(new Date()));
        latch.countDown();//單次任務(wù)結(jié)束,計數(shù)器減一
      } catch (InterruptedException e) {
        e.printStackTrace();
      }
    }
  }
}

由于要同步返回統(tǒng)計數(shù)據(jù),這里我們使用到了CountDownLatch類,它是Java5中新增的一個并發(fā)工具類,其使用非常簡單,參考上面的偽代碼給出了詳細的使用步驟。

CountDownLatch用于同步一個或多個任務(wù),強制他們等待由其他任務(wù)執(zhí)行的一組操作完成。CountDownLatch典型的用法是將一個程序分為N個互相獨立的可解決任務(wù),并創(chuàng)建值為N的CountDownLatch。當(dāng)每一個任務(wù)完成時,都會在這個鎖存器上調(diào)用countDown,等待問題被解決的任務(wù)調(diào)用這個鎖存器的await,將他們自己攔住,直至鎖存器計數(shù)結(jié)束。

具體的源碼解讀,大家可以參考: 源碼分析之CountDownLatch

項目源碼:https://gitee.com/52itstyle/spring-data-jpa

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringAOP中的切點表達式Pointcut詳解

    SpringAOP中的切點表達式Pointcut詳解

    這篇文章主要介紹了SpringAOP中的切點表達式Pointcut詳解,Spring?的?AOP?中的一個核心概念是切點(Pointcut),切點表達式定義通知(Advice)執(zhí)行的范圍,需要的朋友可以參考下
    2023-08-08
  • 關(guān)于java.util.Random的實現(xiàn)原理詳解

    關(guān)于java.util.Random的實現(xiàn)原理詳解

    Java實用工具類庫中的類java.util.Random提供了產(chǎn)生各種類型隨機數(shù)的方法,下面這篇文章主要給大家介紹了關(guān)于java.util.Random實現(xiàn)原理的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下。
    2017-08-08
  • Java通過導(dǎo)出超大Excel文件解決內(nèi)存溢出問題

    Java通過導(dǎo)出超大Excel文件解決內(nèi)存溢出問題

    導(dǎo)出excel是咱Java開發(fā)的必備技能,下面這篇文章主要給大家介紹了關(guān)于Java通過導(dǎo)出超大Excel文件解決內(nèi)存溢出問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2021-09-09
  • JMeter配置元件詳解

    JMeter配置元件詳解

    JMeter提供了豐富的配置元件,常用的包括參數(shù)化配置元件、HTTP請求默認(rèn)值、HTTP信息頭管理器、計數(shù)器等,本文就詳細的介紹一下這些元件的使用,感興趣的可以了解一下
    2021-12-12
  • SpringBoot整合mybatis簡單案例過程解析

    SpringBoot整合mybatis簡單案例過程解析

    這篇文章主要介紹了SpringBoot整合mybatis簡單案例過程解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • springboot項目配置logback日志系統(tǒng)的實現(xiàn)

    springboot項目配置logback日志系統(tǒng)的實現(xiàn)

    這篇文章主要介紹了springboot項目配置logback日志系統(tǒng)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Java實現(xiàn)可視化走迷宮小游戲的示例代碼

    Java實現(xiàn)可視化走迷宮小游戲的示例代碼

    這篇文章主要介紹了Java如何實現(xiàn)可視化走迷宮小游戲。本程序適用于java程序員鞏固類與對象、文件讀取、事件響應(yīng)、awt包中各種工具的相關(guān)概念以及對邏輯能力的鍛煉,需要的可以參考一下
    2022-11-11
  • Java URL自定義私有網(wǎng)絡(luò)協(xié)議

    Java URL自定義私有網(wǎng)絡(luò)協(xié)議

    URI與URL的區(qū)別 一.先來序言一段 二.協(xié)議的自定義的理解 三.自定義協(xié)議與URL的關(guān)系 四.URL自定義私有協(xié)議實戰(zhàn) 五.后話,自定義mineType解析器
    2016-04-04
  • Java線程間的通信方式詳解

    Java線程間的通信方式詳解

    這篇文章主要為大家詳細介紹了Java線程間的通信方式,以代碼結(jié)合文字的方式來討論線程間的通信,感興趣的朋友可以參考一下
    2016-05-05
  • java實現(xiàn)隨機數(shù)生成器

    java實現(xiàn)隨機數(shù)生成器

    這篇文章主要為大家詳細介紹了java實現(xiàn)隨機數(shù)生成器,隨機數(shù)生成小程序,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12

最新評論