如何使用CountDownLatch同步java多線程
最近寫了一個并發(fā)冪等測試,用線程池加入多個線程,同時啟動,領導覺得這樣有一定的風險,要求更嚴格一點,把所有的線程加入池中,然后同時啟動。
本來有多種方法,因為我們需要從多個線程中獲取返回值,所以我們用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在中文中就是門栓的意思,這樣就很好理解了,當有門栓時,latch.await()的線程都在等待,只有當門栓的個數(shù)為0時那些線程才能同時釋放出來,所以能同步運行多線程。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關文章:
1. Java8內存模型PermGen Metaspace實例解析2. python excel和yaml文件的讀取封裝3. python如何實現(xiàn)word批量轉HTML4. python3實現(xiàn)往mysql中插入datetime類型的數(shù)據(jù)5. python爬蟲實戰(zhàn)之制作屬于自己的一個IP代理模塊6. moment轉化時間戳出現(xiàn)Invalid Date的問題及解決7. Python中內建模塊collections如何使用8. 詳解docker pull 下來的鏡像都存到了哪里9. 關于 Android WebView 的內存泄露問題10. Docker鏡像管理常用操作代碼示例
