java四种线程池类型以及可选择的阻塞队列
之前筆記有記錄java線程池的拒絕策略,回顧一下線程池的處理任務(wù)的優(yōu)先級:
先考慮corePoolSize、任務(wù)隊列(緩沖隊列)workQueue、最大線程maximumPoolSize,如果三者都滿了,使用handler處理被拒絕的任務(wù)。
即:
如果運行的線程少于corePoolSize,則 Executor 始終首選添加新的線程,而不進行排隊。(如果當(dāng)前運行的線程小于corePoolSize,則任務(wù)根本不會存入queue中,而是直接運行)?
如果運行的線程大于等于 corePoolSize,則 Executor始終首選將請求加入隊列,而不添加新的線程。?
如果無法將請求加入隊列,則創(chuàng)建新的線程,除非創(chuàng)建此線程超出 maximumPoolSize,在這種情況下,任務(wù)將被拒絕。?
?
BlockingQueue <Runnable> workQueue 這個緩沖隊列有三種類型:
1、直接提交SynchronousQueue
2、無界隊列LinkedBlockingQueue
3、有界隊列ArrayBlockingQueue
?
四種常用線程池:
1、newCachedThreadPool:內(nèi)部使用SynchronousQueue
2、newFixedThreadPool:內(nèi)部使用
3、newScheduledThreadPool:內(nèi)部使用DelayedWorkQueue
4、newSingleThreadExecutor
(一般不要直接用包裝好的,根據(jù)具體問題自行使用參數(shù)創(chuàng)建)
?
***問題:如果沒達到核心線程的時候如果再有請求的時候為什么還會創(chuàng)建新線程?就算有空閑線程?
vimi說:“代碼邏輯”
if(沒滿){新建 } else{if(還有空閑){這時候才插入到空閑} else{再去考慮加入隊列以及拒絕策略} }
參考:https://zhuanlan.zhihu.com/p/32867181
?
轉(zhuǎn)載于:https://www.cnblogs.com/LinsenLi/p/9771195.html
總結(jié)
以上是生活随笔為你收集整理的java四种线程池类型以及可选择的阻塞队列的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 分布式高并发
- 下一篇: 作业三——原型化系统——外卖app