Java線程池的增長過程

Java線程池的增長過程
通過ThreadPoolExecutor的方式創建線程池
ThreadPoolExecutor 構造方法:

複製代碼
public ThreadPoolExecutor(int corePoolSize,

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

}
複製代碼
參數的意義:

1.corePoolSize 指定了線程池裏的線程數量,核心線程池大小
2.maximumPoolSize 指定了線程池裏的最大線程數量
3.keepAliveTime 當線程池線程數量大於corePoolSize時候,多出來的空閒線程,多長時間會被銷燬。
4.unit 時間單位
5.workQueue 任務隊列,用於存放提交但是尚未被執行的任務。
6.threadFactory 線程工廠,用於創建線程,一般可以用默認的
7.handler 拒絕策略,當任務過多時候,如何拒絕任務。當提交任務數超過maximumPoolSize + workQueue 的size之和,任務交給RejectedExecutionHandler 處理

線程池的增長
線程池的增長與創建自定義線程池時設置的參數密切相關,重點講解比較容易讓人誤解的 corePoolsize, maximumPoolsize, workQueue之 間關係。

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

當線程池小於corePoolsize時,新提交的任務將創建一個新的線程執行任務,即使此時線程池中存在空閒線程。
當線程池達到corePoolSize時,新提交的任務將被放入workQueue中,等待線程池中任務調度執行
當workQueue已滿,且線程池當提交任務數超過 maximumPoolSize 時,新提交任務由RejectedExecutionHandlier處理
另外需要特別注意的是,當線程池中超過corePoolSize線程,空閒時間達到keepAliveTime時,將會關閉空閒線程。
當設置allowCoreThreadTimeOut(true)時,線程池中corePoolSize線程空閒時間達到keepAliveTime也將關閉

當一個任務通過execute( Runnable)方法欲添加到線程池時:
如果此時線程池中的數量小於corePoolSize,即使線程池中的線程都處於空閒狀態,也要創建新的線程來處理被添加的任務。
如果此時線程池中的數量等於corePoolSize,但是緩衝隊列workQueue未滿,那麼任務被放入緩衝隊列。
如果此時線程池中的數量大於corePoolSize,緩衝隊列workQueue滿,並且線程池中的數量小於maximumPoolSize,建新的線程來處理被添加的任務。
如果此時線程池中的數量大於corePoolSize,緩衝隊列workQueue滿,並且線程池中的數量等於maximumPoolSize,那麼通過handler所指定的策略來處理此任務。也就是:處理任務的優先級爲:核心線程corePoolSize、 任務隊列workQueue、 最大線程maximumPoolSize,
如果三者都滿了,使用RejectedExecutionHandlier處理被拒絕的任務。(具體怎麼處理,屬於拒絕策略的範疇)
當線程池中的線程數量大於corePoolSize時,如果某線程空閒時間超過keepAliveTime,線程將被終止。這樣,線程池可以動態的調整池中的線程數。
說的再好,不如行動。不怕慢,就怕站。
原文地址https://www.cnblogs.com/ibigboy/p/11298010.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章