您好,登錄后才能下訂單哦!
這篇文章主要講解了“怎么使用Java中的線程池”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“怎么使用Java中的線程池”吧!
Java提供的線程池相關的工具類中,最核心的是ThreadPoolExecutor
ThreadPoolExecutor的構造函數非常復雜,如下面代碼所示,這個最完備的構造函數有7個參數
ThreadPoolExecutor( int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, ThreadFactory threadFactory, RejectedExecutionHandler handler)
下面我們一一介紹這些參數的意義,你可以把線程池類比為一個項目組,而線程就是項目組的成員。
corePoolSize:表示線程池保有的最小線程數。有些項目很閑,但是也不能把人都撤了,至少要留 corePoolSize 個人堅守陣地。
maximumPoolSize:表示線程池創建的最大線程數。當項目很忙時,就需要加人,但是也不能無限制地加,最多就加到maximumPoolSize個人。當項目閑下來時,就要撤人了,最多能撤到corePoolSize個人。
keepAliveTime & unit:上面提到項目根據忙閑來增減人員,那在編程世界里,如何定義忙和閑呢?很簡單,一個線程如果在一段時間內,都沒有執行任務,說明很閑,keepAliveTime 和 unit 就是用來定義這個“一段時間”的參數。也就是說,如果一個線程空閑了keepAliveTime & unit這么久,而且線程池的線程數大于 corePoolSize ,那么這個空閑的線程就要被回收了。
workQueue:工作隊列。
threadFactory:通過這個參數你可以自定義如何創建線程,例如你可以給線程指定一個有意義的名字。
handler:通過這個參數你可以自定義任務的拒絕策略。如果線程池中所有的線程都在忙碌,并且工作隊列也滿了(前提是工作隊列是有界隊列),那么此時提交任務,線程池就會拒絕接收。至于拒絕的策略,你可以通過handler這個參數來指定。ThreadPoolExecutor已經提供了以下4種策略。
CallerRunsPolicy:提交任務的線程自己去執行該任務。
AbortPolicy:默認的拒絕策略,會throws RejectedExecutionException。
DiscardPolicy:直接丟棄任務,沒有任何異常拋出。
DiscardOldestPolicy:丟棄最老的任務,其實就是把最早進入工作隊列的任務丟棄,然后把新任務加入到工作隊列。
Java在1.6版本還增加了 allowCoreThreadTimeOut(boolean value) 方法,它可以讓所有線程都支持超時,這意味著如果項目很閑,就會將項目組的成員都撤走。
感謝各位的閱讀,以上就是“怎么使用Java中的線程池”的內容了,經過本文的學習后,相信大家對怎么使用Java中的線程池這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。