SpringBoot CountDownLatch多任務(wù)并行處理的實現(xiàn)方法
前言
最近在做一個原始成績統(tǒng)計的功能,用戶通過前臺設(shè)置相關(guān)參數(shù),后臺實時統(tǒng)計并返回數(shù)據(jù)。相對來說統(tǒng)計功能點還是比較多的,這里大體羅列一下。
- 個人排名
- 本次測試的優(yōu)良線、及格線、低分線
- 各個班級的排名人數(shù)(1-25、26-50 類比等等)
- 各個班級的前X名人數(shù)統(tǒng)計(前10、前20 類比等等)
- 各個班級的分?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ā)工具類,其使用非常簡單,參考上面的偽代碼給出了詳細(xì)的使用步驟。
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)文章
java 查找list中重復(fù)數(shù)據(jù)實例詳解
這篇文章主要介紹了java 查找list中重復(fù)數(shù)據(jù)實例詳解的相關(guān)資料,需要的朋友可以參考下2017-01-01
Java tomcat環(huán)境變量及idea配置解析
這篇文章主要介紹了Java tomcat環(huán)境變量及idea配置解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-12-12
詳解最簡單易懂的Spring Security 身份認(rèn)證流程講解
這篇文章主要介紹了詳解最簡單易懂的Spring Security 身份認(rèn)證流程講解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-03-03
Spring Security將用戶數(shù)據(jù)存儲到數(shù)據(jù)庫的方法
這篇文章主要介紹了Spring Security將用戶數(shù)據(jù)存儲到數(shù)據(jù)庫的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
SpringBoot實現(xiàn)多文件上傳的詳細(xì)示例代碼
文件上傳中并沒有什么太多的知識點,下面這篇文章主要給大家介紹了關(guān)于SpringBoot實現(xiàn)多文件上傳的詳細(xì)示例,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03
利用Java實體bean對象批量數(shù)據(jù)傳輸處理方案小結(jié)
javabean是對面向?qū)ο笏枷氲囊环N具體實施的表現(xiàn),本文重點給大家介紹利用Java實體bean對象批量數(shù)據(jù)傳輸處理方案小結(jié),本文通過兩種方案給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2021-05-05
詳解BeanUtils.copyProperties()方法如何使用
這篇文章主要為大家介紹了詳解BeanUtils.copyProperties()方法如何使用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07

