成人视屏在线观看-国产99精品-国产精品1区2区-欧美一级在线观看-国产一区二区日韩-色九九九

您的位置:首頁技術(shù)文章
文章詳情頁

Java使用線程池的優(yōu)勢有哪些

瀏覽:69日期:2022-08-25 11:24:47

池化技術(shù)相比大家已經(jīng)屢見不鮮了,線程池、數(shù)據(jù)庫連接池、Http 連接池等等都是對這個思想的應(yīng)用。池化技術(shù)的思想主要是為了減少每次獲取資源的消耗,提高對資源的利用率。 線程池提供了一種限制和管理資源(包括執(zhí)行一個任務(wù))。 每個線程池還維護(hù)一些基本統(tǒng)計信息,例如已完成任務(wù)的數(shù)量。

這里借用《Java 并發(fā)編程的藝術(shù)》提到的來說一下使用線程池的好處:

降低資源消耗。通過重復(fù)利用已創(chuàng)建的線程降低線程創(chuàng)建和銷毀造成的消耗。 提高響應(yīng)速度。當(dāng)任務(wù)到達(dá)時,任務(wù)可以不需要的等到線程創(chuàng)建就能立即執(zhí)行。 提高線程的可管理性。線程是稀缺資源,如果無限制的創(chuàng)建,不僅會消耗系統(tǒng)資源,還會降低系統(tǒng)的穩(wěn)定性,使用線程池可以進(jìn)行統(tǒng)一的分配,調(diào)優(yōu)和監(jiān)控。

Executor 框架

Executor 框架是 Java5 之后引進(jìn)的,在 Java 5 之后,通過 Executor 來啟動線程比使用 Thread 的 start 方法更好,除了更易管理,效率更好(用線程池實現(xiàn),節(jié)約開銷)外,還有關(guān)鍵的一點:有助于避免 this 逃逸問題。

補(bǔ)充:this 逃逸是指在構(gòu)造函數(shù)返回之前其他線程就持有該對象的引用. 調(diào)用尚未構(gòu)造完全的對象的方法可能引發(fā)令人疑惑的錯誤。

Executor 框架不僅包括了線程池的管理,還提供了線程工廠、隊列以及拒絕策略等,Executor 框架讓并發(fā)編程變得更加簡單。

Executor 框架結(jié)構(gòu)(主要由三大部分組成)

任務(wù)(Runnable /Callable) 執(zhí)行任務(wù)需要實現(xiàn)的 Runnable 接口 或 Callable接口。Runnable 接口或 Callable 接口 實現(xiàn)類都可以被 ThreadPoolExecutor 或 ScheduledThreadPoolExecutor 執(zhí)行。 任務(wù)的執(zhí)行(Executor) 如下圖所示,包括任務(wù)執(zhí)行機(jī)制的核心接口 Executor ,以及繼承自 Executor 接口的 ExecutorService 接口。ThreadPoolExecutor 和 ScheduledThreadPoolExecutor 這兩個關(guān)鍵類實現(xiàn)了 ExecutorService 接口。

這里提了很多底層的類關(guān)系,但是,實際上我們需要更多關(guān)注的是 ThreadPoolExecutor 這個類,這個類在我們實際使用線程池的過程中,使用頻率還是非常高的。

注意: 通過查看 ScheduledThreadPoolExecutor 源代碼我們發(fā)現(xiàn) ScheduledThreadPoolExecutor 實際上是繼承了 ThreadPoolExecutor 并實現(xiàn)了 ScheduledExecutorService ,而 ScheduledExecutorService 又實現(xiàn)了 ExecutorService,正如我們下面給出的類關(guān)系圖顯示的一樣。

ThreadPoolExecutor 類描述:

//AbstractExecutorService實現(xiàn)了ExecutorService接口public class ThreadPoolExecutor extends AbstractExecutorService

ScheduledThreadPoolExecutor 類描述:

//ScheduledExecutorService實現(xiàn)了ExecutorService接口public class ScheduledThreadPoolExecutor extends ThreadPoolExecutor implements ScheduledExecutorService

Java使用線程池的優(yōu)勢有哪些

3) 異步計算的結(jié)果(Future) Future 接口以及 Future 接口的實現(xiàn)類 FutureTask 類都可以代表異步計算的結(jié)果。

當(dāng)我們把 Runnable接口 或 Callable 接口 的實現(xiàn)類提交給 ThreadPoolExecutor 或 ScheduledThreadPoolExecutor 執(zhí)行。(調(diào)用 submit() 方法時會返回一個 FutureTask 對象)

Executor 框架的使用示意圖

Java使用線程池的優(yōu)勢有哪些

主線程首先要創(chuàng)建實現(xiàn) Runnable 或者 Callable 接口的任務(wù)對象。 把創(chuàng)建完成的實現(xiàn) Runnable/Callable接口的 對象直接交給 ExecutorService 執(zhí)行: ExecutorService.execute(Runnable command))或者也可以把 Runnable 對象或Callable 對象提交給 ExecutorService 執(zhí)行(ExecutorService.submit(Runnable task)或 ExecutorService.submit(Callable task))。 如果執(zhí)行 ExecutorService.submit(…),ExecutorService 將返回一個實現(xiàn)Future接口的對象(我們剛剛也提到過了執(zhí)行 execute()方法和 submit()方法的區(qū)別,submit()會返回一個 FutureTask 對象)。由于 FutureTask 實現(xiàn)了 Runnable,我們也可以創(chuàng)建 FutureTask,然后直接交給 ExecutorService 執(zhí)行。 最后,主線程可以執(zhí)行 FutureTask.get()方法來等待任務(wù)執(zhí)行完成。主線程也可以執(zhí)行 FutureTask.cancel(boolean mayInterruptIfRunning)來取消此任務(wù)的執(zhí)行。

以上就是Java使用線程池的優(yōu)勢有哪些的詳細(xì)內(nèi)容,更多關(guān)于Java 線程池的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 91国在线啪精品一区 | 亚洲欧美精品一区二区 | 亚洲欧美日韩国产精品一区 | 久久久久久综合一区中文字幕 | 国产精品久久久久久久久免费hd | 99精品免费 | 日本一区毛片免费观看 | 泰国情欲片寂寞的寡妇在线观看 | 国产精品伦理久久久久 | 九九九热在线精品免费全部 | 成人午夜两性视频免费看 | 国产高清在线精品一区a | 精品日本一区二区三区在线观看 | 欧美另类videosbestsex久久 | 欧美一级免费大片 | 色综合久久88中文字幕 | 成人在线免费看 | 麻豆影音 | 成人看的一级毛片 | 日韩一级片在线免费观看 | 午夜一级毛片免费视频 | 亚洲在线久久 | 国产亚洲精品片a77777 | 亚洲乱码一区二区三区国产精品 | 亚欧视频在线观看 | 一区二区三区视频免费观看 | 91大神大战丝袜美女在线观看 | 欧美特级午夜一区二区三区 | 国产成人在线影院 | 亚洲精品国产男人的天堂 | 在线综合+亚洲+欧美中文字幕 | 国产制服 国产制服一区二区 | 日本高清免费视频www | 99久久99热精品免费观看国产 | 国产精品毛片一区二区三区 | 国内精品久久久久久中文字幕 | 午夜成人免费影院 | 久草网视频在线 | 久久厕所视频 | 精品一区二区高清在线观看 | 九九热久久免费视频 |