Java使用線程池的優(yōu)勢(shì)有哪些
池化技術(shù)相比大家已經(jīng)屢見不鮮了,線程池、數(shù)據(jù)庫(kù)連接池、Http 連接池等等都是對(duì)這個(gè)思想的應(yīng)用。池化技術(shù)的思想主要是為了減少每次獲取資源的消耗,提高對(duì)資源的利用率。 線程池提供了一種限制和管理資源(包括執(zhí)行一個(gè)任務(wù))。 每個(gè)線程池還維護(hù)一些基本統(tǒng)計(jì)信息,例如已完成任務(wù)的數(shù)量。
這里借用《Java 并發(fā)編程的藝術(shù)》提到的來說一下使用線程池的好處:
- 降低資源消耗。通過重復(fù)利用已創(chuàng)建的線程降低線程創(chuàng)建和銷毀造成的消耗。
- 提高響應(yīng)速度。當(dāng)任務(wù)到達(dá)時(shí),任務(wù)可以不需要的等到線程創(chuàng)建就能立即執(zhí)行。
- 提高線程的可管理性。線程是稀缺資源,如果無限制的創(chuàng)建,不僅會(huì)消耗系統(tǒng)資源,還會(huì)降低系統(tǒng)的穩(wěn)定性,使用線程池可以進(jìn)行統(tǒng)一的分配,調(diào)優(yōu)和監(jiān)控。
Executor 框架
Executor 框架是 Java5 之后引進(jìn)的,在 Java 5 之后,通過 Executor 來啟動(dòng)線程比使用 Thread 的 start 方法更好,除了更易管理,效率更好(用線程池實(shí)現(xiàn),節(jié)約開銷)外,還有關(guān)鍵的一點(diǎn):有助于避免 this 逃逸問題。
補(bǔ)充:this 逃逸是指在構(gòu)造函數(shù)返回之前其他線程就持有該對(duì)象的引用. 調(diào)用尚未構(gòu)造完全的對(duì)象的方法可能引發(fā)令人疑惑的錯(cuò)誤。
Executor 框架不僅包括了線程池的管理,還提供了線程工廠、隊(duì)列以及拒絕策略等,Executor 框架讓并發(fā)編程變得更加簡(jiǎn)單。
Executor 框架結(jié)構(gòu)(主要由三大部分組成)
- 任務(wù)(Runnable /Callable) 執(zhí)行任務(wù)需要實(shí)現(xiàn)的 Runnable 接口 或 Callable接口。Runnable 接口或 Callable 接口 實(shí)現(xiàn)類都可以被 ThreadPoolExecutor 或 ScheduledThreadPoolExecutor 執(zhí)行。
- 任務(wù)的執(zhí)行(Executor) 如下圖所示,包括任務(wù)執(zhí)行機(jī)制的核心接口 Executor ,以及繼承自 Executor 接口的 ExecutorService 接口。ThreadPoolExecutor 和 ScheduledThreadPoolExecutor 這兩個(gè)關(guān)鍵類實(shí)現(xiàn)了 ExecutorService 接口。
這里提了很多底層的類關(guān)系,但是,實(shí)際上我們需要更多關(guān)注的是 ThreadPoolExecutor 這個(gè)類,這個(gè)類在我們實(shí)際使用線程池的過程中,使用頻率還是非常高的。
注意: 通過查看 ScheduledThreadPoolExecutor 源代碼我們發(fā)現(xiàn) ScheduledThreadPoolExecutor 實(shí)際上是繼承了 ThreadPoolExecutor 并實(shí)現(xiàn)了 ScheduledExecutorService ,而 ScheduledExecutorService 又實(shí)現(xiàn)了 ExecutorService,正如我們下面給出的類關(guān)系圖顯示的一樣。
ThreadPoolExecutor 類描述:
//AbstractExecutorService實(shí)現(xiàn)了ExecutorService接口 public class ThreadPoolExecutor extends AbstractExecutorService
ScheduledThreadPoolExecutor 類描述:
//ScheduledExecutorService實(shí)現(xiàn)了ExecutorService接口 public class ScheduledThreadPoolExecutor extends ThreadPoolExecutor implements ScheduledExecutorService
3) 異步計(jì)算的結(jié)果(Future) Future 接口以及 Future 接口的實(shí)現(xiàn)類 FutureTask 類都可以代表異步計(jì)算的結(jié)果。
當(dāng)我們把 Runnable接口 或 Callable 接口 的實(shí)現(xiàn)類提交給 ThreadPoolExecutor 或 ScheduledThreadPoolExecutor 執(zhí)行。(調(diào)用 submit() 方法時(shí)會(huì)返回一個(gè) FutureTask 對(duì)象)
Executor 框架的使用示意圖
- 主線程首先要?jiǎng)?chuàng)建實(shí)現(xiàn) Runnable 或者 Callable 接口的任務(wù)對(duì)象。
- 把創(chuàng)建完成的實(shí)現(xiàn) Runnable/Callable接口的 對(duì)象直接交給 ExecutorService 執(zhí)行: ExecutorService.execute(Runnable command))或者也可以把 Runnable 對(duì)象或Callable 對(duì)象提交給 ExecutorService 執(zhí)行(ExecutorService.submit(Runnable task)或 ExecutorService.submit(Callable task))。
- 如果執(zhí)行 ExecutorService.submit(…),ExecutorService 將返回一個(gè)實(shí)現(xiàn)Future接口的對(duì)象(我們剛剛也提到過了執(zhí)行 execute()方法和 submit()方法的區(qū)別,submit()會(huì)返回一個(gè) FutureTask 對(duì)象)。由于 FutureTask 實(shí)現(xiàn)了 Runnable,我們也可以創(chuàng)建 FutureTask,然后直接交給 ExecutorService 執(zhí)行。
- 最后,主線程可以執(zhí)行 FutureTask.get()方法來等待任務(wù)執(zhí)行完成。主線程也可以執(zhí)行 FutureTask.cancel(boolean mayInterruptIfRunning)來取消此任務(wù)的執(zhí)行。
以上就是Java使用線程池的優(yōu)勢(shì)有哪些的詳細(xì)內(nèi)容,更多關(guān)于Java 線程池的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- 深入理解Java線程池從設(shè)計(jì)思想到源碼解讀
- Java 自定義線程池和線程總數(shù)控制操作
- 教你如何監(jiān)控 Java 線程池運(yùn)行狀態(tài)的操作(必看)
- java高級(jí)應(yīng)用:線程池的全面講解(干貨)
- java多線程CountDownLatch與線程池ThreadPoolExecutor/ExecutorService案例
- Java線程池配置的一些常見誤區(qū)總結(jié)
- java中常見的6種線程池示例詳解
- java ThreadPool線程池的使用,線程池工具類用法說明
- 談?wù)凧ava 線程池
- Java 判斷線程池所有任務(wù)是否執(zhí)行完畢的操作
- Java 使用線程池執(zhí)行多個(gè)任務(wù)的示例
相關(guān)文章
Android內(nèi)存泄漏實(shí)戰(zhàn)解析
Java是垃圾回收語言的一種。這篇文章主要介紹了Android內(nèi)存泄漏 的相關(guān)資料,需要的朋友可以參考下2016-10-10Sentinel Dashboard限流規(guī)則保存方式
這篇文章主要介紹了Sentinel Dashboard限流規(guī)則保存方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06Java數(shù)據(jù)機(jī)構(gòu)中關(guān)于并查集的詳解
并查集是一種樹型的數(shù)據(jù)結(jié)構(gòu),用于處理一些不相交集合的合并及查詢問題,如果你還不了解并查集,請(qǐng)看接下來的文章,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值2021-09-09解決Java壓縮zip異常java.util.zip.ZipException:duplicate entry
這篇文章主要介紹了解決Java壓縮zip異常java.util.zip.ZipException:duplicate entry:問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12