久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

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

Java countDownLatch如何實現(xiàn)多線程任務(wù)阻塞等待

瀏覽:28日期:2022-08-22 16:58:58

我這里需要通過多線程去處理數(shù)據(jù),然后在所有數(shù)據(jù)都處理完成后再往下執(zhí)行。這里就用到了CountDownLatch。把countdownlatch作為參數(shù)傳入到每個線程類里,在線程中處理完數(shù)據(jù)后執(zhí)行countdown方法。在所有countdownlatch歸零后,其await方法結(jié)束阻塞狀態(tài)而往下執(zhí)行。

具體代碼如下:

將多線程任務(wù)提交線程池

@Bean(name = 'ggnews_executor')public Executor postExecutor() {ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();executor.setCorePoolSize(1);executor.setMaxPoolSize(1);executor.setQueueCapacity(1);executor.setKeepAliveSeconds(120);executor.setThreadNamePrefix('executor-');executor.setRejectedExecutionHandler(new ThreadPoolExecutor.DiscardPolicy());return executor;}//通過定時任務(wù)調(diào)用的fetch方法,為了避免定時任務(wù)在多次執(zhí)行中失效,通異步指定線程池的方式進(jìn)行調(diào)用@Async('ggnews_executor')public void fetch() {if(fetchFlag.getAndSet(false)) {List<FetchTag> tags = fetchTagService.selectFetchTagList(fetchTag);CountDownLatch downLatch = new CountDownLatch(tags.size());for (FetchTag tag : tags) {FetchTag tagNew;try {tagNew =(FetchTag) tag.clone();} catch (Throwable e) {log.error('',e);continue;}//作為參數(shù)將CountDownLatch傳入InnerRunner innerRunner = new InnerRunner(downLatch, tagNew);executor.execute(innerRunner);}try {//等待線程執(zhí)行完畢,如果十分鐘后還沒結(jié)束也會停止阻塞狀態(tài)downLatch.await(10,TimeUnit.MINUTES);fetchFlag.getAndSet(true);} catch (Throwable e) {log.error('fetch()方法發(fā)生錯誤:{}', e);fetchFlag.getAndSet(true);//e.printStackTrace();} finally {fetchFlag.getAndSet(true);}} else {log.info('=======上次抓取尚未結(jié)束=========');}}

InnerRunner為要執(zhí)行具體任務(wù)的線程類

private class InnerRunner implements Runnable {private CountDownLatch downLatch;private FetchTag tag;private InnerRunner(CountDownLatch downLatch, FetchTag tag) {this.downLatch = downLatch;this.tag = tag;}@Overridepublic void run() { //將countDown方法移入到具體方法中的finally塊中,以保證即使在拋出異常的情況下也算執(zhí)行了此次任務(wù),countdown會被執(zhí)行fetchGG(tag.getTag(), downLatch);//downLatch.countDown();this.tag = null;}}

private static final String GOOGLE_URL_IN = 'https://news.google.com/rss/search?hl=hi&gl=IN&ceid=IN:hi&q=';public void fetchGG(String tag, CountDownLatch downLatch) {try {Document document = Jsoup.parse(new URL(GOOGLE_URL_IN + URLEncoder.encode(''' + tag + ''', 'utf-8')), 30000);Elements elements = document.getElementsByTag('item');int rank = 1;for (Element element : elements) {String sourceTitle = element.getElementsByTag('title').get(0).text();log.info('source title:' + sourceTitle);}} catch (Throwable e) {log.info('fetch google url error', e);} finally { //肯定會被執(zhí)行downLatch.countDown();}}

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

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 精品国产乱码久久久久久闺蜜 | 黄色大片网 | 亚洲欧美激情精品一区二区 | 高清av网站 | 日韩高清在线播放 | 黄色av网站在线观看 | 中文字幕成人在线 | 国变精品美女久久久久av爽 | 久久成人综合网 | 视频精品一区二区三区 | 91精品久久 | 精品国产伦一区二区三区观看说明 | 久久久精品综合 | av一区二区三区四区 | 久久国产精品免费一区二区三区 | 国产欧美一区二区精品婷 | 精品九九九 | 色婷婷一区二区三区四区 | 青草成人免费视频 | 亚洲精品日本 | 噜噜噜在线 | 成人在线观看中文字幕 | 综合五月 | 一色桃子av一区二区免费 | 福利网站在线观看 | 国产精品免费视频一区 | 在线视频亚洲 | 中文字幕1区| 韩日精品在线观看 | 成人欧美一区二区三区白人 | 国产精品99久久久久久宅男 | 久久国产精品久久精品 | 欧美黄色一区 | 老司机午夜免费精品视频 | 日日操视频| 欧美日韩国产综合视频 | 天天插天天干 | 久久综合色88 | 求av网址| 国产福利在线免费 | 国产欧美一区二区三区在线看 |