溫馨提示×

溫馨提示×

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

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

線程池的工作流程是什么

發(fā)布時間:2021-10-28 14:36:37 來源:億速云 閱讀:147 作者:iii 欄目:web開發(fā)

本篇內(nèi)容主要講解“線程池的工作流程是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“線程池的工作流程是什么”吧!

線程池的各種參數(shù)

面試的時候最常問的就是線程池的各種參數(shù)的含義,和線程池的整個運(yùn)行流程,這個一定要會

ThreadPoolExecutor一共有4個構(gòu)造函數(shù),但最后調(diào)用的都是如下構(gòu)造函數(shù)

參數(shù)含義
corePoolSize核心線程池大小
maximumPoolSize線程池最大容量大小
keepAliveTime線程池空閑時,線程存活的時間
TimeUnit線程活動保持時間的單位
BlockingQueue<Runnable>任務(wù)隊列,用于保存等待執(zhí)行的任務(wù)的阻塞隊列
ThreadFactory用于設(shè)置線程的工廠
RejectedExecutionHandler飽和策略

來類比學(xué)習(xí)一下這些參數(shù),我們把線程池類比為項目組,線程是這個公司的成員

corePoolSize:線程池中最少的線程數(shù),一個項目組總得有corePoolSize人堅守陣地,都是簽訂勞動合同了,不能隨便撤。

maximumPoolSize:當(dāng)項目很忙時,就得加人,請其他項目組的人來幫忙。但是公司空間有限,最多只能加到maximumPoolSize個人。當(dāng)項目閑了,就得撤人了,最多能撤到corePoolSize個人

keepAliveTime &  unit:上面提到項目根據(jù)忙閑來增減人員,那在編程世界里,如何定義忙和閑呢?如果一個線程在keepAliveTime(時間數(shù)字)*  unit(時間單位)時間內(nèi)都沒有執(zhí)行任務(wù),說明這個線程很閑。如果此時線程數(shù)大于corePoolSize,這個線程就要被回收了

workQueue:就是任務(wù)隊列

threadFactory:自定義如果創(chuàng)建線程,例如給線程指定一個有意義的名字

handler:workQueue滿了(排期滿了),再提交任務(wù),該怎么處理呢?這個就是處理策略,線程池提供了4種策略,你也可以實(shí)現(xiàn)RejectedExecutionHandler接口來自定義策略

策略
AbortPolicy丟棄任務(wù),拋運(yùn)行時異常(默認(rèn)的處理策略)
CallerRunsPolicy執(zhí)行任務(wù)
DiscardPolicy忽視,什么都不會發(fā)生
DiscardOldestPolicy丟棄隊列里最近的一個任務(wù),并執(zhí)行當(dāng)前任務(wù)

線程池的工作流程

可以參照一下源碼理解一下下面的流程

1.線程池剛創(chuàng)建時,里面沒有一個線程。任務(wù)隊列是作為參數(shù)傳進(jìn)來的。不過,就算隊列里面有任務(wù),線程池也不會馬上執(zhí)行他們。

2.當(dāng)調(diào)用execute()方法添加一個任務(wù)時,線程池會做如下判斷:

a. 如果正在運(yùn)行的線程數(shù)量小于corePoolSize,那么馬上創(chuàng)建線程運(yùn)行這個任務(wù)

b. 如果正在運(yùn)行的線程數(shù)量大于或等于corePoolSize,那么將這個任務(wù)放入隊列

c. 如果這時候隊列滿了,而且正在運(yùn)行的線程數(shù)量小于maximunPoolSize,那么還是要創(chuàng)建非核心線程立刻運(yùn)行這個任務(wù)

d.  如果隊列滿了,而且正在運(yùn)行的線程數(shù)量大于或等于maximunPoolSize,那么線程池會拋出RejectedExecutionException

3.當(dāng)一個線程完成任務(wù)時,它會從隊列中取下一個任務(wù)來執(zhí)行

4.當(dāng)一個線程無事可做,超過一定的時間(keepAliveTime)時,線程池會判斷,如果當(dāng)前運(yùn)行的線程數(shù)大于corePoolSize,那么這個線程就被停掉。所以線程池的所有任務(wù)完成后,它最終會收縮到corePoolSize的大小

可以用如下圖來表示整體流程

線程池的工作流程是什么

到此,相信大家對“線程池的工作流程是什么”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

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

AI