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

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

Java ExecutorServic線程池異步實現流程

瀏覽:2日期:2022-08-20 10:26:34

相信大家都在項目中遇到過這樣的情況,前臺需要快速的顯示,后臺還需要做一個很大的邏輯。比如:前臺點擊數據導入按鈕,按鈕后的服務端執行邏輯A,和邏輯B(執行大量的表數據之間的copy功能),而這時前臺不能一直等著,要返回給前臺,告訴正在處理中就行了。這里就需要用到異步了。

點擊按鈕 -> 邏輯A ->邏輯B(異步) -> 方法結束。

到底,項目需求明確了,就引入了ExecutorServic線程池。

Java通過Executors提供四種線程池,分別為:

newCachedThreadPool創建一個可緩存線程池,如果線程池長度超過處理需要,可靈活回收空閑線程,若無可回收,則新建線程。 newFixedThreadPool 創建一個定長線程池,可控制線程最大并發數,超出的線程會在隊列中等待。 newScheduledThreadPool 創建一個定長線程池,支持定時及周期性任務執行。 newSingleThreadExecutor 創建一個單線程化的線程池,它只會用唯一的工作線程來執行任務,保證所有任務按照指定順序(FIFO, LIFO, 優先級)執行。

import java.util.concurrent.Callable;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;/** * @author szy * @version 創建時間:2018-5-20 上午10:25:06 * */public class Testasync { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub if(task0() == true){ System.out.println('執行完畢,看異步結果'); } } public static void task1(){ System.out.println('task1 is start'); } public static void task2(){ ExecutorService executor = Executors.newFixedThreadPool(1); executor.submit(new Callable(){ @Override public Object call() throws Exception {// TODO Auto-generated method stub//增加睡眠時間,便于查看結果/* try { Thread.sleep(10000); } catch (InterruptedException e) { e.printStackTrace(); }*/ //異步提交int sum = 0;for (int i = 0; i < 10000; i++) { sum += i;}System.out.println('task2執行數據的大量導入或者導出');System.out.println('task2='+sum);System.out.println('task2導入或者導出完成');return null; } }); } public static void task3(){ System.out.println('task3 is start'); int j = 0; while(true) { if(j++ > 10) {break; } System.out.println('------------task3 end-----------'); } } public static boolean task0(){ task1(); task2(); task3(); return true; }}

然后看結果:

task1 is starttask3 is start------------task3 end-----------------------task3 end-----------------------task3 end-----------------------task3 end-----------------------task3 end-----------------------task3 end-----------------------task3 end-----------------------task3 end-----------------------task3 end-----------------------task3 end-----------------------task3 end-----------task2執行數據的大量導入或者導出執行完畢,看異步結果task2=49995000task2導入或者導出完成

可以看出,task1 和task3先執行了,并且方法在沒有等待task2的情況下,直接結束了。

異步的task2另開了一個線程,自己在執行。和主線程已經無關了。

不過,這種在eclipse中以deubug模式是看不出來的。

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

標簽: Java
相關文章:
主站蜘蛛池模板: 免费一级毛片 | 午夜一级大片 | 色呦呦网站 | 亚洲一区二区免费 | 激情伊人网 | 一区二区三区久久 | 日韩成人精品 | 高清人人天天夜夜曰狠狠狠狠 | 日韩av一区二区在线 | 久久久精品天堂 | 国产999精品久久久久久 | 交专区videossex农村 | 精品三级 | 久久亚洲一区二区三 | 精品亚洲一区二区 | 欧美精品在线观看 | 午夜视频在线观看视频 | 精品一二区 | 久久不卡区 | 欧美日韩精品一区二区三区视频 | 一级毛片在线播放 | 国产激情视频在线 | 亚洲va欧美va天堂v国产综合 | 人人cao | 91视频.com | 欧美九九 | 久久精品视频网站 | 日韩精品1区2区3区 国产精品国产成人国产三级 | 久久免费观看一级毛片 | 久久亚洲综合 | 在线视频中文字幕 | 日本高清中文字幕 | 视频一区二区在线观看 | 免费毛片网| 日韩精品一区二区三区高清免费 | 亚洲激情网站 | 欧美日韩国产不卡 | 午夜伦理影院 | 亚洲欧美一区二区三区在线 | 亚洲精品一区二区在线观看 | 亚洲高清三级 |