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

Java 線程池核心參數(shù)、執(zhí)行流程與實(shí)戰(zhàn)建議全解析

 更新時(shí)間:2025年04月22日 10:11:03   作者:扶風(fēng)_w  
主要介紹了 Java 線程池:核心參數(shù)、執(zhí)行流程與實(shí)戰(zhàn)建議,我將用最通俗的方式帶你搞懂 Java 線程池,從構(gòu)造函數(shù)開(kāi)始,講透執(zhí)行機(jī)制、參數(shù)配置,再結(jié)合我在真實(shí)項(xiàng)目中的使用經(jīng)驗(yàn),總結(jié)出一套實(shí)戰(zhàn)建議,需要的朋友可以參考下

在 Java 后端開(kāi)發(fā)中,線程池 是個(gè)“看起來(lái)簡(jiǎn)單,用起來(lái)復(fù)雜”的工具。你可能已經(jīng)在項(xiàng)目中用過(guò) @Async、Executors.newFixedThreadPool() 或者自己 new 一個(gè) ThreadPoolExecutor。但你是否真的理解線程池的工作原理?它背后的執(zhí)行流程?又該如何避免那些隱藏的坑?

這篇文章,我將用最通俗的方式帶你搞懂 Java 線程池,從構(gòu)造函數(shù)開(kāi)始,講透執(zhí)行機(jī)制、參數(shù)配置,再結(jié)合我在真實(shí)項(xiàng)目中的使用經(jīng)驗(yàn),總結(jié)出一套實(shí)戰(zhàn)建議。

一、為什么需要線程池?

Java 中創(chuàng)建一個(gè)新線程是相當(dāng)“昂貴”的操作:

  • 每創(chuàng)建一個(gè)線程就意味著新的內(nèi)存棧空間、調(diào)度開(kāi)銷;
  • 創(chuàng)建頻繁還可能導(dǎo)致系統(tǒng)資源耗盡(尤其是高并發(fā)場(chǎng)景);

使用線程池能帶來(lái)的好處:

  • ? 降低資源消耗(復(fù)用已創(chuàng)建線程);
  • ? 提高響應(yīng)速度(任務(wù)無(wú)需等待創(chuàng)建線程);
  • ? 統(tǒng)一管理線程行為(可控的隊(duì)列長(zhǎng)度、最大線程數(shù)、異常捕獲等);

所以 —— 不管你是做 Web、爬蟲、數(shù)據(jù)處理還是異步任務(wù),線程池都值得你精通

二、ThreadPoolExecutor 構(gòu)造函數(shù)詳解

Java 提供了一個(gè)核心類:ThreadPoolExecutor,它是所有線程池實(shí)現(xiàn)的基礎(chǔ)。它的構(gòu)造函數(shù)如下:

public ThreadPoolExecutor(
    int corePoolSize, // 核心線程數(shù)
    int maximumPoolSize, // 最大線程數(shù)
    long keepAliveTime, // 線程存活時(shí)間
    TimeUnit unit, // 時(shí)間單位
    BlockingQueue<Runnable> workQueue, // 隊(duì)列
    ThreadFactory threadFactory, // 線程工廠
    RejectedExecutionHandler handler // 拒絕策略
)

看起來(lái)很多參數(shù)?別怕,我們一個(gè)個(gè)講。 

參數(shù)含義推薦配置思路
corePoolSize核心線程數(shù)一般為 CPU 核數(shù) 或 稍高
maximumPoolSize最大線程數(shù)比 corePoolSize 稍高,用于應(yīng)急突發(fā)流量
keepAliveTime + unit非核心線程存活時(shí)間通常設(shè)為 60 秒
workQueue任務(wù)等待隊(duì)列推薦使用有界隊(duì)列(避免 OOM)
threadFactory線程工廠自定義線程名,方便定位問(wèn)題
handler拒絕策略看業(yè)務(wù)選,一般用 CallerRuns 或 自定義

三、線程池任務(wù)執(zhí)行流程圖

整個(gè)線程池處理流程大致如下:

  • 當(dāng)任務(wù)進(jìn)來(lái)時(shí),如果當(dāng)前運(yùn)行的線程數(shù) < corePoolSize,就新建線程執(zhí)行任務(wù);
  • 否則判斷隊(duì)列是否滿,如果隊(duì)列沒(méi)滿,就放入隊(duì)列排隊(duì);
  • 如果隊(duì)列滿了,并且線程數(shù) < maximumPoolSize,就新建線程執(zhí)行任務(wù);
  • 如果線程數(shù)也達(dá)到最大了,那就執(zhí)行拒絕策略。

你可以理解為三道門檻:核心線程數(shù) -> 隊(duì)列容量 -> 最大線程數(shù)。

四、常見(jiàn)拒絕策略(你一定要掌握)

策略名行為是否推薦
AbortPolicy直接拋出異常? 有風(fēng)險(xiǎn)(默認(rèn))
CallerRunsPolicy由調(diào)用者線程執(zhí)行任務(wù)? 穩(wěn)妥,節(jié)流
DiscardPolicy直接丟棄任務(wù)? 極端
DiscardOldestPolicy丟棄最早排隊(duì)任務(wù)?? 業(yè)務(wù)非重要時(shí)可用

五、實(shí)戰(zhàn)配置案例

下面是一個(gè)我在真實(shí)項(xiàng)目中使用過(guò)的線程池配置:

public class ThreadPoolUtil {
    public static ExecutorService getExecutor() {
        return new ThreadPoolExecutor(
            4, 10,
            60, TimeUnit.SECONDS,
            new LinkedBlockingQueue<>(1000),
            new NamedThreadFactory("order-processor"),
            new ThreadPoolExecutor.CallerRunsPolicy()
        );
    }
}

?? 為什么這么配置?

  • 核心線程4個(gè):適合 4核CPU;
  • 最大10個(gè):預(yù)留處理突發(fā)任務(wù);
  • 隊(duì)列1000:合理緩存任務(wù),避免頻繁 reject;
  • 線程命名:方便日志中查問(wèn)題;
  • CallerRuns策略:觸頂時(shí)交給主線程,自動(dòng)限流;

六、那些你可能忽略的坑

  • 不關(guān)閉線程池:使用完后不調(diào)用 shutdown(),可能導(dǎo)致程序無(wú)法正常退出。
  • 濫用 Executors 工具類:如 newFixedThreadPool() 使用無(wú)界隊(duì)列,newCachedThreadPool() 最大線程數(shù)過(guò)大,容易內(nèi)存溢出。建議使用 ThreadPoolExecutor 明確指定參數(shù)。
  • 誤用 submit()submit() 返回 Future,即使任務(wù)出錯(cuò)也不會(huì)拋異常,必須通過(guò) get() 才能發(fā)現(xiàn)。若無(wú)需返回結(jié)果,推薦使用 execute()。

七、最佳實(shí)踐總結(jié)

? 使用有界隊(duì)列,控制資源使用
? 命名線程,方便排查日志問(wèn)題
? 合理配置 core 和 max,大膽使用 CPU 核數(shù)
? 拒絕策略慎選,推薦 CallerRuns
? 封裝線程池為工具類,便于復(fù)用
? 定期監(jiān)控線程池狀態(tài)(線程數(shù)、隊(duì)列長(zhǎng)度)

?? 寫在最后

線程池是一個(gè)非常核心的基礎(chǔ)組件,很多系統(tǒng)的性能瓶頸、并發(fā)問(wèn)題、甚至線上事故,都可能跟線程池配置有關(guān)。

如果你看完本文,能:

  • 搞清楚線程池的構(gòu)造邏輯
  • 能正確配置線程池參數(shù)
  • 避免常見(jiàn)的使用坑

那么我覺(jué)得這篇文章的目的就達(dá)到了。

到此這篇關(guān)于 Java 線程池:核心參數(shù)、執(zhí)行流程與實(shí)戰(zhàn)建議的文章就介紹到這了,更多相關(guān)java線程池核心參數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot高版本修改為低版本時(shí)測(cè)試類報(bào)錯(cuò)的解決方案

    SpringBoot高版本修改為低版本時(shí)測(cè)試類報(bào)錯(cuò)的解決方案

    這篇文章主要介紹了SpringBoot高版本修改為低版本時(shí)測(cè)試類報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • Java基于裝飾者模式實(shí)現(xiàn)的染色饅頭案例詳解

    Java基于裝飾者模式實(shí)現(xiàn)的染色饅頭案例詳解

    這篇文章主要介紹了Java基于裝飾者模式實(shí)現(xiàn)的染色饅頭案例,簡(jiǎn)單描述了裝飾者模式的概念、原理及Java使用裝飾者模式的相關(guān)實(shí)現(xiàn)步驟、操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2018-05-05
  • Java中將異步調(diào)用轉(zhuǎn)為同步的五種實(shí)現(xiàn)方法

    Java中將異步調(diào)用轉(zhuǎn)為同步的五種實(shí)現(xiàn)方法

    本文介紹了將異步調(diào)用轉(zhuǎn)為同步阻塞模式的五種方法:wait/notify、ReentrantLock+Condition、Future、CountDownLatch和CyclicBarrier,每種方法都有其適用場(chǎng)景和核心機(jī)制,可以根據(jù)具體需求選擇合適的方法,需要的朋友可以參考下
    2025-02-02
  • Java序列化和反序列化_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    Java序列化和反序列化_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    把對(duì)象轉(zhuǎn)換為字節(jié)序列的過(guò)程稱為對(duì)象的序列化,把字節(jié)序列恢復(fù)為對(duì)象的過(guò)程稱為對(duì)象的反序列化。接下來(lái)通過(guò)本文給大家介紹Java序列化和反序列化及主要的兩種用途,感興趣的的友參考下吧
    2017-05-05
  • java自定義注解實(shí)現(xiàn)前后臺(tái)參數(shù)校驗(yàn)的實(shí)例

    java自定義注解實(shí)現(xiàn)前后臺(tái)參數(shù)校驗(yàn)的實(shí)例

    下面小編就為大家?guī)?lái)一篇java自定義注解實(shí)現(xiàn)前后臺(tái)參數(shù)校驗(yàn)的實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-11-11
  • Spring?Boot?微服務(wù)中集成?MyBatis-Plus?與集成原生?MyBatis在配置上的不同

    Spring?Boot?微服務(wù)中集成?MyBatis-Plus?與集成原生?MyBatis在配置上的不同

    在Spring?Boot微服務(wù)中,MyBatis-Plus通過(guò)其Boot?Starter和豐富的配置屬性,極大的簡(jiǎn)化了MyBatis的集成和配置工作,尤其是對(duì)于全局設(shè)置和常用插件的使用,本文給大家介紹Spring?Boot?微服務(wù)中集成?MyBatis-Plus與集成原生?MyBatis?有哪些配置上的不同,感興趣的朋友一起看看吧
    2025-04-04
  • 詳解Mybatis Generator的具體使用教程

    詳解Mybatis Generator的具體使用教程

    Mybatis Generator可以幫助我們自動(dòng)生成很多結(jié)構(gòu)化的代碼,比如每張表對(duì)應(yīng)的Entity、Mapper接口和Xml文件,可以省去很多繁瑣的工作,今天通過(guò)本文給大家介紹Mybatis Generator的具體使用教程,感興趣的朋友一起看看吧
    2022-02-02
  • Mapper層繼承BaseMapper<T>需要引入的pom依賴方式

    Mapper層繼承BaseMapper<T>需要引入的pom依賴方式

    這篇文章主要介紹了Mapper層繼承BaseMapper<T>需要引入的pom依賴方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • 通過(guò)實(shí)例解析java String不可變性

    通過(guò)實(shí)例解析java String不可變性

    這篇文章主要介紹了通過(guò)實(shí)例解析java String不可變性,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • SpringBoot中接收POST參數(shù)的幾種方式詳解

    SpringBoot中接收POST參數(shù)的幾種方式詳解

    這篇文章主要介紹了SpringBoot中接收POST參數(shù)的幾種方式,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-06-06

最新評(píng)論