SpringBoot CountDownLatch多任務(wù)并行處理的實(shí)現(xiàn)方法
前言
最近在做一個(gè)原始成績(jī)統(tǒng)計(jì)的功能,用戶(hù)通過(guò)前臺(tái)設(shè)置相關(guān)參數(shù),后臺(tái)實(shí)時(shí)統(tǒng)計(jì)并返回?cái)?shù)據(jù)。相對(duì)來(lái)說(shuō)統(tǒng)計(jì)功能點(diǎn)還是比較多的,這里大體羅列一下。
- 個(gè)人排名
- 本次測(cè)試的優(yōu)良線(xiàn)、及格線(xiàn)、低分線(xiàn)
- 各個(gè)班級(jí)的排名人數(shù)(1-25、26-50 類(lèi)比等等)
- 各個(gè)班級(jí)的前X名人數(shù)統(tǒng)計(jì)(前10、前20 類(lèi)比等等)
- 各個(gè)班級(jí)的分?jǐn)?shù)段學(xué)生人數(shù)統(tǒng)計(jì)(150-140、139-130 類(lèi)比等等)
最好的用戶(hù)體驗(yàn),就是每一個(gè)操作都可以實(shí)時(shí)的展示數(shù)據(jù),3秒之內(nèi)應(yīng)該是用戶(hù)的忍受范圍之內(nèi)的了,所以做一款產(chǎn)品不僅要考慮用戶(hù)交互設(shè)計(jì),后端的優(yōu)化也是比不可少的。
大家可以簡(jiǎn)單的看下以上這5項(xiàng)統(tǒng)計(jì)數(shù)據(jù),總體來(lái)說(shuō),統(tǒng)計(jì)量還是不少的。最主要的還是要實(shí)時(shí)、實(shí)時(shí)、實(shí)時(shí)(重要的事情說(shuō)三遍),顯然定時(shí)任務(wù)是不現(xiàn)實(shí)的。
改造前
程序邏輯
順序執(zhí)行任務(wù).png
改造后
程序邏輯
多任務(wù)并行處理.png
多任務(wù)并行處理,適用于多核CPU,單核CPU多線(xiàn)程執(zhí)行任務(wù)可能會(huì)適得其反(上下文切換以及線(xiàn)程的創(chuàng)建和銷(xiāo)毀都會(huì)消耗資源),特別是CPU密集型的任務(wù)。
代碼實(shí)現(xiàn)
StatsDemo偽代碼:
/** * 多任務(wù)并行統(tǒng)計(jì) * 創(chuàng)建者 科幫網(wǎng) * 創(chuàng)建時(shí)間 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);// 兩個(gè)賽跑者 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開(kāi)始執(zhí)行 stats2.start();//任務(wù)B開(kāi)始執(zhí)行 stats3.start();//任務(wù)C開(kāi)始執(zhí)行 stats4.start();//任務(wù)D開(kāi)始執(zhí)行 stats5.start();//任務(wù)E開(kāi)始執(zhí)行 latch.await();// 等待所有人任務(wù)結(jié)束 System.out.println("所有的統(tǒng)計(jì)任務(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í)行時(shí)間 Thread.sleep(runTime); System.out.println(statsName + " do stats complete at "+ sdf.format(new Date())); latch.countDown();//單次任務(wù)結(jié)束,計(jì)數(shù)器減一 } catch (InterruptedException e) { e.printStackTrace(); } } } }
由于要同步返回統(tǒng)計(jì)數(shù)據(jù),這里我們使用到了CountDownLatch類(lèi),它是Java5中新增的一個(gè)并發(fā)工具類(lèi),其使用非常簡(jiǎn)單,參考上面的偽代碼給出了詳細(xì)的使用步驟。
CountDownLatch用于同步一個(gè)或多個(gè)任務(wù),強(qiáng)制他們等待由其他任務(wù)執(zhí)行的一組操作完成。CountDownLatch典型的用法是將一個(gè)程序分為N個(gè)互相獨(dú)立的可解決任務(wù),并創(chuàng)建值為N的CountDownLatch。當(dāng)每一個(gè)任務(wù)完成時(shí),都會(huì)在這個(gè)鎖存器上調(diào)用countDown,等待問(wèn)題被解決的任務(wù)調(diào)用這個(gè)鎖存器的await,將他們自己攔住,直至鎖存器計(jì)數(shù)結(jié)束。
具體的源碼解讀,大家可以參考: 源碼分析之CountDownLatch
項(xiàng)目源碼:https://gitee.com/52itstyle/spring-data-jpa
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringAOP中的切點(diǎn)表達(dá)式Pointcut詳解
這篇文章主要介紹了SpringAOP中的切點(diǎn)表達(dá)式Pointcut詳解,Spring?的?AOP?中的一個(gè)核心概念是切點(diǎn)(Pointcut),切點(diǎn)表達(dá)式定義通知(Advice)執(zhí)行的范圍,需要的朋友可以參考下2023-08-08關(guān)于java.util.Random的實(shí)現(xiàn)原理詳解
Java實(shí)用工具類(lèi)庫(kù)中的類(lèi)java.util.Random提供了產(chǎn)生各種類(lèi)型隨機(jī)數(shù)的方法,下面這篇文章主要給大家介紹了關(guān)于java.util.Random實(shí)現(xiàn)原理的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下。2017-08-08Java通過(guò)導(dǎo)出超大Excel文件解決內(nèi)存溢出問(wèn)題
導(dǎo)出excel是咱Java開(kāi)發(fā)的必備技能,下面這篇文章主要給大家介紹了關(guān)于Java通過(guò)導(dǎo)出超大Excel文件解決內(nèi)存溢出問(wèn)題的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-09-09SpringBoot整合mybatis簡(jiǎn)單案例過(guò)程解析
這篇文章主要介紹了SpringBoot整合mybatis簡(jiǎn)單案例過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11springboot項(xiàng)目配置logback日志系統(tǒng)的實(shí)現(xiàn)
這篇文章主要介紹了springboot項(xiàng)目配置logback日志系統(tǒng)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04Java實(shí)現(xiàn)可視化走迷宮小游戲的示例代碼
這篇文章主要介紹了Java如何實(shí)現(xiàn)可視化走迷宮小游戲。本程序適用于java程序員鞏固類(lèi)與對(duì)象、文件讀取、事件響應(yīng)、awt包中各種工具的相關(guān)概念以及對(duì)邏輯能力的鍛煉,需要的可以參考一下2022-11-11Java URL自定義私有網(wǎng)絡(luò)協(xié)議
URI與URL的區(qū)別 一.先來(lái)序言一段 二.協(xié)議的自定義的理解 三.自定義協(xié)議與URL的關(guān)系 四.URL自定義私有協(xié)議實(shí)戰(zhàn) 五.后話(huà),自定義mineType解析器2016-04-04java實(shí)現(xiàn)隨機(jī)數(shù)生成器
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)隨機(jī)數(shù)生成器,隨機(jī)數(shù)生成小程序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12