java并發(fā)編程(1):并發(fā)編程框架簡(jiǎn)介

1、Executor框架

Executor框架構(gòu)建線程池及任務(wù)調(diào)度處理。

Executor框架.png

Executor接口:線程執(zhí)行的基本接口,用戶通過(guò)此接口提交任務(wù)給線程或線程池執(zhí)行;
ExecutorSevice接口:線程池相關(guān)操作接口,定義了線程池的維護(hù)、任務(wù)提交及狀態(tài)維護(hù)等相關(guān)接口;
AbstractExecutorService抽象類(lèi):ExecutorSevice接口的抽象實(shí)現(xiàn);
ThreadPoolExecutor線程池類(lèi):線程池的具體實(shí)現(xiàn)類(lèi),實(shí)現(xiàn)了線程池的創(chuàng)建、維護(hù)等,任務(wù)的提交、任務(wù)隊(duì)列的維護(hù)、任務(wù)的分發(fā)執(zhí)行等相關(guān)操作。
ScheduledThreadPoolExecutor:繼承于ThreadPoolExecutor的實(shí)現(xiàn)類(lèi),可基于時(shí)間延時(shí)或時(shí)間間隔進(jìn)行任務(wù)執(zhí)行和調(diào)度等;
ForkJoinPool:繼承于AbstractExecutorService,基于任務(wù)拆分結(jié)果聚合的架構(gòu);
DelegatedExecutorService:由Executors工具類(lèi)實(shí)現(xiàn),ExecutorService的包裝器類(lèi),使得ExecutorService不可變;
FinalizableDelegatedExecutorService:由Executors工具類(lèi)實(shí)現(xiàn),實(shí)現(xiàn)了finalize()方法的DelegatedExecutorService類(lèi);
DelegatedScheduledExecutorService:由Executors工具類(lèi)實(shí)現(xiàn),基于時(shí)間延遲和時(shí)間間隔調(diào)度的DelegatedExecutorService類(lèi);

2、Future框架

Future封裝異步執(zhí)行結(jié)果等數(shù)據(jù);

Future框架.png

Future:封裝異步執(zhí)行的結(jié)果及任務(wù)狀態(tài)等;
RunnableFuture:繼承于Runnable及Future接口;
FutureTask:封裝了線程、任務(wù)、任務(wù)狀態(tài)維護(hù)、任務(wù)結(jié)果、等待隊(duì)列等相關(guān)信息;
ScheduledFutureTask:繼承于FutureTask,同時(shí)保存了任務(wù)調(diào)度時(shí)間相關(guān)信息。
ForkJoinTask:封裝了任務(wù)拆分及結(jié)果聚合相關(guān)處理;

3、BlockingQueue阻塞隊(duì)列

BlockingQueue為任務(wù)隊(duì)列,是任務(wù)生產(chǎn)和線程消費(fèi)的緩存通道。

BlockingQueue阻塞隊(duì)列.png

BlockingQueue:阻塞隊(duì)列接口,封裝對(duì)象添加及獲取的相關(guān)接口;
ArrayBlockingQueue:基于數(shù)組實(shí)現(xiàn)的阻塞隊(duì)列;
LinkedBlockingQueue:基于隊(duì)列實(shí)現(xiàn)的阻塞隊(duì)列;
PriorityBlockingQueue:支持優(yōu)先級(jí)的阻塞隊(duì)列;
DelayedWorkQueue:基于時(shí)間延遲的排序的隊(duì)列,主要在ScheduledThreadPoolExecutor中使用。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 一.線程安全性 線程安全是建立在對(duì)于對(duì)象狀態(tài)訪問(wèn)操作進(jìn)行管理,特別是對(duì)共享的與可變的狀態(tài)的訪問(wèn) 解釋下上面的話: ...
    黃大大吃不胖閱讀 952評(píng)論 0 3
  • 一、并發(fā) 進(jìn)程:每個(gè)進(jìn)程都擁有自己的一套變量 線程:線程之間共享數(shù)據(jù) 1.線程 Java中為多線程任務(wù)提供了很多的...
    SeanMa閱讀 2,802評(píng)論 0 11
  • https://blog.csdn.net/defonds/article/details/44021605/ 譯...
    huangxiongbiao閱讀 1,374評(píng)論 0 11
  • 1.簡(jiǎn)介 如果并發(fā)的線程數(shù)量很多,并且每個(gè)線程都是執(zhí)行一個(gè)時(shí)間很短的任務(wù)就結(jié)束了,這樣頻繁創(chuàng)建線程就會(huì)大大降低系統(tǒng)...
    htkeepmoving閱讀 589評(píng)論 0 2
  • 把子女培養(yǎng)成“聽(tīng)話”的孩子,是父母轉(zhuǎn)嫁了自己的焦慮,同時(shí)也給孩子帶來(lái)了嚴(yán)重的心理問(wèn)題。這是雙輸局面,對(duì)誰(shuí)也沒(méi)有好處...
    精靈兒飛閱讀 309評(píng)論 1 1

友情鏈接更多精彩內(nèi)容