大多數(shù)并發(fā)應(yīng)用程序都是圍繞“任務(wù)執(zhí)行”來構(gòu)造的:任務(wù)通常是一些抽象且離散的工作單元。通過把應(yīng)用程序的工作分解到多個(gè)任務(wù)中蚓挤,可以簡化程序的組織結(jié)構(gòu)。而“任務(wù)執(zhí)行”離不開線程估灿,但線程的創(chuàng)建和管理是非常復(fù)雜的,為了簡化這些復(fù)雜的線程管理模式馅袁,我們需要一個(gè)線程管理者來統(tǒng)一管理線程及任務(wù)分配,這就是線程池抵窒。 從本章開始李皇,我們將對(duì)并發(fā)編程中另一個(gè)非常重要的概念-線程池進(jìn)行詳細(xì)的講解削茁。
????任務(wù)是一組邏輯工作單元卓囚,而線程則是使任務(wù)異步執(zhí)行的機(jī)制富寿。而使用線程來管理任務(wù)執(zhí)行,務(wù)必要考慮“為每個(gè)任務(wù)分配一個(gè)線程”的資源管理的復(fù)雜性银萍,而線程池則簡化了線程的管理工作,從JDK1.5開始麻捻,Java 類庫提供了這種靈活的線程池框架-Executor。它為靈活且強(qiáng)大的異步任務(wù)執(zhí)行執(zhí)行提供了基礎(chǔ)摊腋,該框架能支持多種不同類型的任務(wù)執(zhí)行策略视粮,提供了一種標(biāo)準(zhǔn)的方法將任務(wù)的提交過程與執(zhí)行過程解耦開來。并且 Executor 的實(shí)現(xiàn)還提供了對(duì)生命周期的支持类咧,以及統(tǒng)計(jì)信息收集馒铃、應(yīng)用程序管理機(jī)制和性能監(jiān)視等機(jī)制蟹腾。
框架結(jié)構(gòu)
- Executor:線程池的最上層接口痕惋,提供了任務(wù)提交的基礎(chǔ)方法。
- ExecutorService:提供了線程池管理的上層接口娃殖,如池銷毀值戳、任務(wù)提交、異步任務(wù)提交炉爆。
- ScheduledExecutorService:提供任務(wù)定時(shí)或周期執(zhí)行方法的 ExecutorService堕虹。
- AbstractExecutorService:為 ExecutorService 的任務(wù)提交方法提供了默認(rèn)實(shí)現(xiàn)。
- ThreadPoolExecutor:大名鼎鼎線程池類芬首,提供線程和任務(wù)的調(diào)度策略赴捞。
- ScheduledThreadPoolExecutor:屬于線程池的一種,它可以允許任務(wù)延遲或周期執(zhí)行郁稍,類似java的Timer赦政。
- ForkJoinPool:JDK1.7加入的成員,也是線程池的一種耀怜。只允許執(zhí)行 ForkJoinTask 任務(wù)恢着,它是為那些能夠被遞歸地拆解成子任務(wù)的工作類型量身設(shè)計(jì)的。其目的在于能夠使用所有可用的運(yùn)算資源來提升應(yīng)用性能财破。
- Executors:創(chuàng)建各種線程池的工具類掰派。
簡單來說,線程池分為三種:基礎(chǔ)線程池ThreadPoolExecutor左痢、延時(shí)任務(wù)線程池 ScheduledThreadPoolExecutor 和分治線程池ForkJoinPool靡羡。每種線程池中都有其支持的任務(wù)類型系洛,后面我們?cè)谠创a分析中,會(huì)穿插講解各個(gè)線程池中遇到的各種任務(wù)類型亿眠。