av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

如果我一直往線程池里面放任務(wù),會發(fā)生什么?

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

我們注重客戶提出的每個(gè)要求,我們充分考慮每一個(gè)細(xì)節(jié),我們積極的做好做網(wǎng)站、成都網(wǎng)站制作服務(wù),我們努力開拓更好的視野,通過不懈的努力,創(chuàng)新互聯(lián)贏得了業(yè)內(nèi)的良好聲譽(yù),這一切,也不斷的激勵(lì)著我們更好的服務(wù)客戶。 主要業(yè)務(wù):網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)站設(shè)計(jì),微信小程序開發(fā),網(wǎng)站開發(fā),技術(shù)開發(fā)實(shí)力,DIV+CSS,PHP及ASP,ASP.Net,SQL數(shù)據(jù)庫的技術(shù)開發(fā)工程師。

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

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

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

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

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

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

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

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

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

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

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

線程池的工作流程

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

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

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

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

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

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

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

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

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

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

本文轉(zhuǎn)載自微信公眾號「 Java識堂」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系 Java識堂公眾號。


當(dāng)前文章:如果我一直往線程池里面放任務(wù),會發(fā)生什么?
URL鏈接:http://uogjgqi.cn/article/dpogcso.html
掃二維碼與項(xiàng)目經(jīng)理溝通

我們在微信上24小時(shí)期待你的聲音

解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流