欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

線程池FutureTask異步執(zhí)行多任務(wù)實(shí)現(xiàn)詳解

 更新時(shí)間:2023年11月15日 10:14:17   作者:zhongh?Jim  
這篇文章主要為大家介紹了線程池FutureTask異步執(zhí)行多任務(wù)實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

題引

之前紅包權(quán)益領(lǐng)取查詢的接口超時(shí)了,因?yàn)橛杏脩粲嗁?gòu)的權(quán)益有點(diǎn)多

解決方案

用線程池+ FutureTask將1個(gè)查詢拆分成多個(gè)小查詢
選擇FutureTask是因?yàn)樗哂袃H執(zhí)行1次run()方法的特性(即使有多次調(diào)用也只執(zhí)行1次),避免了重復(fù)查詢的可能。而且多任務(wù)異步執(zhí)行也能提高接口響應(yīng)速度。

若對(duì)FutureTask僅執(zhí)行1次run()有疑問(wèn),可看: FutureTask為何僅執(zhí)行一次run()?

本文主要講的是線程池搭配FutureTask異步執(zhí)行的例子

一、線程池+FutureTask執(zhí)行多任務(wù)計(jì)算

public class Test {
    //線程池最好作為全局變量, 若作為局部變量記得用完后shutdown()
    ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNameFormat("thread-start-runner-%d").build();
    ExecutorService taskExe= new ThreadPoolExecutor(10,20,800L, TimeUnit.MILLISECONDS,new LinkedBlockingQueue<Runnable>(100),namedThreadFactory);
    
    int count=0;
    @Test
    public void test(String[] args) {
        
        //任務(wù)列表
        List<FutureTask<Integer>> taskList=new ArrayList<FutureTask<Integer>>();
        for(int i=0;i<100;i++){
            //創(chuàng)建100個(gè)任務(wù)放入【任務(wù)列表】
            FutureTask<Integer> futureTask=new FutureTask<Integer>(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    return 1;
                }
            });
            //執(zhí)行的結(jié)果裝回原來(lái)的FutureTask中,后續(xù)直接遍歷集合taskList來(lái)獲取結(jié)果即可
            taskList.add(futureTask);
            taskExe.submit(futureTask);
        }
        //獲取結(jié)果
        try{
            for(FutureTask<Integer> futureTask:taskList){
                count+=futureTask.get();
            }
        } catch (InterruptedException e) {
            logger.error("線程執(zhí)行被中斷",e);
        } catch (ExecutionException e) {
            logger.error("線程執(zhí)行出現(xiàn)異常",e);
        }
        //關(guān)閉線程池
        taskExe.shutdown();
        //打印: 100
        System.out.println(count);
    }
}

Callable接口能讓我們拿到線程的執(zhí)行結(jié)果,所以讓它作為FutureTask構(gòu)造函數(shù)FutureTask(Callable<V> callable)的入?yún)ⅰ?/p>

FutureTask執(zhí)行的結(jié)果會(huì)放入它的私有變量outcome中,其他線程直接調(diào)用futureTask.get()去讀取該變量即可

二、子線程出的異常拋不出的情況

submit(Runnable task)提交任務(wù)的方式 ,是存在“隱患”的:

FutureTask內(nèi)部的run()代碼塊會(huì)把異常給吞進(jìn)去,通過(guò)setException(Throwable t)把異常賦給了對(duì)象outcome,我們?cè)谡{(diào)用FutureTask.get()獲取結(jié)果的時(shí)候返回的就是這個(gè)對(duì)象

如果你的代碼沒(méi)有調(diào)用FutureTask.get(),它不會(huì)把異常吐出來(lái),有可能子線程就莫名的停止了。

public Future<?> submit(Runnable task) {
    if (task == null) throw new NullPointerException();
    //創(chuàng)建一個(gè)異步執(zhí)行的任務(wù)FutureTask, 【隱患】也在它的run()代碼塊里
    RunnableFuture<Void> ftask = newTaskFor(task, null);
    execute(ftask);
    return ftask;
}

子線程創(chuàng)建之后會(huì)執(zhí)行的是FutureTask內(nèi)部的run()代碼塊,run()內(nèi)部會(huì)有try-catch來(lái)截獲拋出的異常,將其賦值給對(duì)象outcome

上面的例子沒(méi)有這個(gè)問(wèn)題,因?yàn)檎{(diào)用了FutureTask.get(),有異常會(huì)從這里拿出來(lái)

關(guān)于線程池的參數(shù)設(shè)置,會(huì)在下文 線程池參數(shù)自定義設(shè)置及詳解中說(shuō)明,在這寫就太長(zhǎng)了

以上就是線程池FutureTask異步執(zhí)行多任務(wù)實(shí)現(xiàn)詳解的詳細(xì)內(nèi)容,更多關(guān)于線程池FutureTask異步執(zhí)行多任務(wù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 解決maven中只有Lifecycle而Dependencies和Plugins消失的問(wèn)題

    解決maven中只有Lifecycle而Dependencies和Plugins消失的問(wèn)題

    這篇文章主要介紹了maven中只有Lifecycle而Dependencies和Plugins消失的問(wèn)題及解決方法,本文通過(guò)圖文的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2020-07-07
  • 從java源碼分析線程池(池化技術(shù))的實(shí)現(xiàn)原理

    從java源碼分析線程池(池化技術(shù))的實(shí)現(xiàn)原理

    這篇文章主要介紹了從java源碼分析線程池(池化技術(shù))的實(shí)現(xiàn)原理,池化技術(shù)是一種編程技巧,當(dāng)程序出現(xiàn)高并發(fā)時(shí),能夠明顯的優(yōu)化程序,降低系統(tǒng)頻繁創(chuàng)建銷毀連接等額外開(kāi)銷,下文更多的相關(guān)介紹需要的小伙伴可以參考一下
    2022-04-04
  • IDEA配置Maven教程的超詳細(xì)講解版

    IDEA配置Maven教程的超詳細(xì)講解版

    IntelliJ IDEA是當(dāng)前最流行的Java IDE(集成開(kāi)發(fā)環(huán)境)之一,也是業(yè)界公認(rèn)最好用的Java開(kāi)發(fā)工具之一,這篇文章主要給大家介紹了關(guān)于IDEA配置Maven教程的超詳細(xì)講解版,需要的朋友可以參考下
    2023-11-11
  • Java中g(shù)etSuperclass()方法的使用與原理解讀

    Java中g(shù)etSuperclass()方法的使用與原理解讀

    文章介紹了Java中的getSuperclass()方法,該方法用于獲取一個(gè)類的直接父類,通過(guò)理解其使用方式、工作原理以及實(shí)際應(yīng)用場(chǎng)景,可以更好地利用反射機(jī)制處理類的繼承關(guān)系,實(shí)現(xiàn)動(dòng)態(tài)類型檢查、類加載以及序列化等功能
    2025-01-01
  • 詳解Spring Boot使用redis實(shí)現(xiàn)數(shù)據(jù)緩存

    詳解Spring Boot使用redis實(shí)現(xiàn)數(shù)據(jù)緩存

    本篇文章主要介紹了詳解Spring Boot使用redis實(shí)現(xiàn)數(shù)據(jù)緩存,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-04-04
  • Java獲取磁盤分區(qū)信息的示例詳解

    Java獲取磁盤分區(qū)信息的示例詳解

    在日常開(kāi)發(fā)、系統(tǒng)監(jiān)控和資源管理中,磁盤分區(qū)信息是非常重要的數(shù)據(jù),本文將基于 Java 語(yǔ)言實(shí)現(xiàn)磁盤分區(qū)信息的獲取功能,感興趣的可以了解下
    2025-03-03
  • java 文件大數(shù)據(jù)Excel下載實(shí)例代碼

    java 文件大數(shù)據(jù)Excel下載實(shí)例代碼

    這篇文章主要介紹了java 文件大數(shù)據(jù)Excel下載實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • java實(shí)現(xiàn)肯德基收銀系統(tǒng)

    java實(shí)現(xiàn)肯德基收銀系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)肯德基收銀系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • java字符串中${}或者{}等的占位符替換工具類

    java字符串中${}或者{}等的占位符替換工具類

    今天小編就為大家分享一篇關(guān)于java字符串中${}或者{}等的占位符替換工具類,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2018-12-12
  • 淺談spring-boot-rabbitmq動(dòng)態(tài)管理的方法

    淺談spring-boot-rabbitmq動(dòng)態(tài)管理的方法

    這篇文章主要介紹了淺談spring-boot-rabbitmq動(dòng)態(tài)管理的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12

最新評(píng)論