如何使用CountDownLatch同步j(luò)ava多線程
最近寫(xiě)了一個(gè)并發(fā)冪等測(cè)試,用線程池加入多個(gè)線程,同時(shí)啟動(dòng),領(lǐng)導(dǎo)覺(jué)得這樣有一定的風(fēng)險(xiǎn),要求更嚴(yán)格一點(diǎn),把所有的線程加入池中,然后同時(shí)啟動(dòng)。
本來(lái)有多種方法,因?yàn)槲覀冃枰獜亩鄠€(gè)線程中獲取返回值,所以我們用CountDownLatch來(lái)同步多線程。CyclicBarrier也是可以同步多線程的,但因?yàn)槠錈o(wú)法獲取返回值,最后只能選擇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在中文中就是門(mén)栓的意思,這樣就很好理解了,當(dāng)有門(mén)栓時(shí),latch.await()的線程都在等待,只有當(dāng)門(mén)栓的個(gè)數(shù)為0時(shí)那些線程才能同時(shí)釋放出來(lái),所以能同步運(yùn)行多線程。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 低版本IE正常運(yùn)行HTML5+CSS3網(wǎng)站的3種解決方案2. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向3. chat.asp聊天程序的編寫(xiě)方法4. 使用XSL將XML文檔中的CDATA注釋輸出為HTML文本5. XML入門(mén)的常見(jiàn)問(wèn)題(一)6. ASP錯(cuò)誤捕獲的幾種常規(guī)處理方式7. 小技巧處理div內(nèi)容溢出8. 告別AJAX實(shí)現(xiàn)無(wú)刷新提交表單9. PHP循環(huán)與分支知識(shí)點(diǎn)梳理10. css進(jìn)階學(xué)習(xí) 選擇符
