亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Java實現限定時間CountDownLatch并行場景

瀏覽:3日期:2022-08-10 16:07:42
目錄業務場景:解決方案:總結業務場景:

一個用戶數據接口,要求在20ms內返回數據,它的調用邏輯復雜,關聯接口多,需要從3個接口匯總數據,這些匯總接口最小耗時也需要16ms,全部匯總接口最優狀態耗時需要16ms*3=48ms

解決方案:

使用并行調用接口,通過多線程同時獲取結果集,最后進行結果整合。在這種場景下,使用concurrent包的CountDownLatch完成相關操作。CountDownLatch本質上是一個計數器,把它初始化為與執行任務相同的數量,當一個任務執行完時,就將計數器的值減1,直到計算器達到0時,表示完成了所有任務,在await上等待線程就繼續執行。

為上述業務場景封裝的工具類,傳入兩個參數:一個參數是計算的task數量,另外一個參數是整個大任務超時的毫秒數。

import java.util.concurrent.ArrayBlockingQueue;import java.util.concurrent.CountDownLatch;import java.util.concurrent.ThreadPoolExecutor;import java.util.concurrent.TimeUnit;public class ParallelCollector { private Long timeout; private CountDownLatch countDownLatch; ThreadPoolExecutor executor = new ThreadPoolExecutor(100, 200, 1, TimeUnit.HOURS, new ArrayBlockingQueue<>(100)); public ParallelCollector(int taskSize, Long timeOutMill) {countDownLatch = new CountDownLatch(taskSize);timeout = timeOutMill; } public void submitTask(Runnable runnable) {executor.execute(() -> { runnable.run(); countDownLatch.countDown();}); } public void await() {try { this.countDownLatch.await(timeout, TimeUnit.MILLISECONDS);} catch (InterruptedException e) { e.printStackTrace();} } public void destroy() {this.executor.shutdown(); }}

當任務運行時間超過了任務的時間上限,就被直接停止,這就是await()的功能。

interface是一個模擬遠程服務的超時的測試類,程序運行后,會輸出執行結果到map集合。

public class InterfaceMock { private volatile int num=1; public String slowMethod1() {try { Thread.sleep(2000);} catch (InterruptedException e) { e.printStackTrace();}return String.valueOf(num+1); }; public String slowMethod2() {return String.valueOf(num+1); }; public String slowMethod3() {return String.valueOf(num+1); };}

并行執行獲取結果測試類

@SpringBootTestclass ThreadPoolApplicationTests { @Test void testTask() {InterfaceMock interfaceMock = new InterfaceMock();ParallelCollector collector = new ParallelCollector(3, 20L);ConcurrentHashMap<String, String> map = new ConcurrentHashMap<>();collector.submitTask(()->map.put('method1',interfaceMock.slowMethod1()));collector.submitTask(()->map.put('method2',interfaceMock.slowMethod2()));collector.submitTask(()->map.put('method3',interfaceMock.slowMethod3()));collector.await();System.out.println(map.toString());collector.destroy(); }}

當method1()執行時間大于20ms,則該方法直接被終止,結果map集沒有method1()的結果,結果如下:

總結

使用這種方式,接口能在固定時間內返回,注意CountDownLatch定義數量是任務個數,使用concurrentHashMap避免了并行執行時發生錯亂,造成錯誤的結果的問題。

到此這篇關于Java實現限定時間CountDownLatch并行場景的文章就介紹到這了,更多相關Java CountDownLatch并行場景內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 真人一级毛片 | www.日本黄 | 特黄特级毛片免费视 | 国产挤奶水在线视频播放 | 黄色片免费 | 青草资源视频在线高清观看 | 日韩美女一级片 | 色网址在线 | 国产伦子一区二区三区四区 | 成人毛片在线 | 中国一级片免费看 | 国产一区中文字幕 | 一级一级一级毛片 | 在线a久青草视频在线观看g | 成人国产精品免费网站 | 亚洲国产成人久久综合一区 | 国产精品一区二区手机看片 | 欧美精品v日韩精品v国产精品 | 成人性生交大片免费看午夜a | 黄色片一级黄色片 | 国产小视频国产精品 | 三级视频中文字幕 | 国语自产精品视频在线区 | 亚洲人人在线 | 亚洲成本人网亚洲视频大全 | 国产成人精品微拍视频 | 久久精品视频免费看 | japanxxxx日本中文字幕 | 在线免费观看黄色片 | 亚洲综合色就色手机在线观看 | 麻豆视频在线观看 | 国产精品色 | 九九老司机在线视频精品 | 好吊色青青青国产在线观看 | 色婷亚洲 | 视频一区视频二区在线观看 | 91精品福利在线 | 亚洲美女视频一区 | 国产在线观看麻豆91精品免费 | 爱爱小视频在线观看网站 | 国产成人精品一区二区免费视频 |