国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

如何使用CountDownLatch同步j(luò)ava多線程

瀏覽:80日期:2022-08-27 13:37:07

最近寫了一個并發(fā)冪等測試,用線程池加入多個線程,同時啟動,領(lǐng)導(dǎo)覺得這樣有一定的風(fēng)險,要求更嚴(yán)格一點,把所有的線程加入池中,然后同時啟動。

本來有多種方法,因為我們需要從多個線程中獲取返回值,所以我們用CountDownLatch來同步多線程。CyclicBarrier也是可以同步多線程的,但因為其無法獲取返回值,最后只能選擇CountDownLatch.

因公司的代碼不便共享,這里只提供一小部分代碼。

CountDownLatch latch = new CountDownLatch(1);

<br data-filtered='filtered'>ExecutorService pool; if (concurrentNum != null&&concurrentNum <= maxConcurrentNum && concurrentNum > 0) {pool = Executors.newFixedThreadPool(concurrentNum); } else { concurrentNum = defaultConcurrentNum; pool = Executors.newFixedThreadPool(defaultConcurrentNum); } for (int i = 0; i < concurrentNum; i++) { Future res = pool.submit(new Callable<Object>() {@Overridepublic Object call() throws Exception { latch.await(); Object retObj = executeApi(); return retObj;} }); resultList.add(res); } latch.countDown(); for (int i = 0; i < concurrentNum; i++) { retList.add(resultList.get(i).get()); } pool.shutdown();

這里順便提一下,latch在中文中就是門栓的意思,這樣就很好理解了,當(dāng)有門栓時,latch.await()的線程都在等待,只有當(dāng)門栓的個數(shù)為0時那些線程才能同時釋放出來,所以能同步運行多線程。

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

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 三亚市| 洪江市| 囊谦县| 鄂伦春自治旗| 宝清县| 江达县| 保德县| 台前县| 普宁市| 铜山县| 黑龙江省| 惠州市| 慈溪市| 绥德县| 天峻县| 县级市| 舒兰市| 怀仁县| 普洱| 威信县| 托克逊县| 德惠市| 九寨沟县| 綦江县| 兴和县| 高要市| 简阳市| 罗城| 中方县| 涪陵区| 商水县| 蒙自县| 中牟县| 安宁市| 凤庆县| 营口市| 瑞丽市| 大港区| 盐源县| 高阳县| 平果县|