av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

Java countDownLatch如何實現多線程任務阻塞等待

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

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

具體代碼如下:

將多線程任務提交線程池

@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;}//通過定時任務調用的fetch方法,為了避免定時任務在多次執行中失效,通異步指定線程池的方式進行調用@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;}//作為參數將CountDownLatch傳入InnerRunner innerRunner = new InnerRunner(downLatch, tagNew);executor.execute(innerRunner);}try {//等待線程執行完畢,如果十分鐘后還沒結束也會停止阻塞狀態downLatch.await(10,TimeUnit.MINUTES);fetchFlag.getAndSet(true);} catch (Throwable e) {log.error('fetch()方法發生錯誤:{}', e);fetchFlag.getAndSet(true);//e.printStackTrace();} finally {fetchFlag.getAndSet(true);}} else {log.info('=======上次抓取尚未結束=========');}}

InnerRunner為要執行具體任務的線程類

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塊中,以保證即使在拋出異常的情況下也算執行了此次任務,countdown會被執行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 { //肯定會被執行downLatch.countDown();}}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 国产一区免费视频 | 精品一区久久 | www.一区 | 伊人9999 | 午夜精品视频在线 | 久操福利 | 久久亚洲精品视频 | 成人黄色免费视频 | 97视频免费 | 性视频网 | 午夜不卡视频 | 久久成人毛片 | aaaaaabbbbbb毛片| 婷婷色网 | 97国产视频 | 午夜在线小视频 | 亚洲视频一区在线观看 | 毛片网站大全 | 国产女人18毛片水18精品 | 黄色片免费 | 一区二区影院 | av片在线免费观看 | 日韩中文视频 | 国产av毛片 | 日韩精品视频在线免费观看 | 国产理论在线观看 | 免费成人结看片 | 伊人成人在线视频 | 国产欧美日本 | 久久久久久国产精品 | 国产又粗又猛又黄又爽的视频 | 久久精品播放 | 一区二区三区国产视频 | 在线观看国产免费视频 | 91狠狠干 | 青娱乐99 | 日韩中文字幕视频 | 久久精品观看 | 亚洲天天看 | 久久99精品久久久久久 | 黄色片亚洲 |