溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

詳解Java線程池的增長過程

發(fā)布時間:2020-09-30 02:31:46 來源:腳本之家 閱讀:171 作者:為何不是夢 欄目:編程語言

通過ThreadPoolExecutor的方式創(chuàng)建線程池

ThreadPoolExecutor 構(gòu)造方法:

public ThreadPoolExecutor(int corePoolSize,
               int maximumPoolSize,
               long keepAliveTime,
               TimeUnit unit,
               BlockingQueue<Runnable> workQueue,
               ThreadFactory threadFactory,
               RejectedExecutionHandler handler) {
    //code...   
}

參數(shù)的意義:

  • 1.corePoolSize 指定了線程池里的線程數(shù)量,核心線程池大小
  • 2.maximumPoolSize 指定了線程池里的最大線程數(shù)量
  • 3.keepAliveTime 當(dāng)線程池線程數(shù)量大于corePoolSize時候,多出來的空閑線程,多長時間會被銷毀。
  • 4.unit 時間單位
  • 5.workQueue 任務(wù)隊列,用于存放提交但是尚未被執(zhí)行的任務(wù)。
  • 6.threadFactory 線程工廠,用于創(chuàng)建線程,一般可以用默認(rèn)的
  • 7.handler 拒絕策略,當(dāng)任務(wù)過多時候,如何拒絕任務(wù)。當(dāng)提交任務(wù)數(shù)超過maximumPoolSize + workQueue 的size之和,任務(wù)交給RejectedExecutionHandler 處理

線程池的增長

線程池的增長與創(chuàng)建自定義線程池時設(shè)置的參數(shù)密切相關(guān),重點講解比較容易讓人誤解的 corePoolsize, maximumPoolsize, workQueue之 間關(guān)系。

先看一張圖,理解一下增長過程

詳解Java線程池的增長過程

當(dāng)線程池小于corePoolsize時,新提交的任務(wù)將創(chuàng)建一個新的線程執(zhí)行任務(wù),即使此時線程池中存在空閑線程。當(dāng)線程池達(dá)到corePoolSize時,新提交的任務(wù)將被放入workQueue中,等待線程池中任務(wù)調(diào)度執(zhí)行當(dāng)workQueue已滿,且線程池<maximumPoolSize 時, 新提交任務(wù)會創(chuàng)建新線程執(zhí)行任務(wù)當(dāng)提交任務(wù)數(shù)超過 maximumPoolSize 時,新提交任務(wù)由RejectedExecutionHandlier處理另外需要特別注意的是,當(dāng)線程池中超過corePoolSize線程,空閑時間達(dá)到keepAliveTime時,將會關(guān)閉空閑線程。當(dāng)設(shè)置allowCoreThreadTimeOut(true)時,線程池中corePoolSize線程空閑時間達(dá)到keepAliveTime也將關(guān)閉
當(dāng)一個任務(wù)通過execute( Runnable)方法欲添加到線程池時:
如果此時線程池中的數(shù)量小于corePoolSize,即使線程池中的線程都處于空閑狀態(tài),也要創(chuàng)建新的線程來處理被添加的任務(wù)。如果此時線程池中的數(shù)量等于corePoolSize,但是緩沖隊列workQueue未滿,那么任務(wù)被放入緩沖隊列。如果此時線程池中的數(shù)量大于corePoolSize,緩沖隊列workQueue滿,并且線程池中的數(shù)量小于maximumPoolSize,建新的線程來處理被添加的任務(wù)。 如果此時線程池中的數(shù)量大于corePoolSize,緩沖隊列workQueue滿,并且線程池中的數(shù)量等于maximumPoolSize,那么通過handler所指定的策略來處理此任務(wù)。也就是:處理任務(wù)的優(yōu)先級為:核心線程corePoolSize、 任務(wù)隊列workQueue、 最大線程maximumPoolSize, 如果三者都滿了,使用RejectedExecutionHandlier處理被拒絕的任務(wù)。(具體怎么處理,屬于拒絕策略的范疇)
當(dāng)線程池中的線程數(shù)量大于corePoolSize時,如果某線程空閑時間超過keepAliveTime,線程將被終止。這樣,線程池可以動態(tài)的調(diào)整池中的線程數(shù)。
以上就是關(guān)于Java線程池的增長過程全部知識點,感謝大家對億速云的支持。
向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI