国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

java高級應(yīng)用:線程池的全面講解(干貨)

瀏覽:5日期:2022-08-16 09:25:20

java高級應(yīng)用:線程池的全面講解(干貨)

什么是線程池?

很簡單,簡單看名字就知道是裝有線程的池子,我們可以把要執(zhí)行的多線程交給線程池來處理,和連接池的概念一樣,通過維護(hù)一定數(shù)量的線程池來達(dá)到多個(gè)線程的復(fù)用。

線程池的好處

我們知道不用線程池的話,每個(gè)線程都要通過new Thread(xxRunnable).start()的方式來創(chuàng)建并運(yùn)行一個(gè)線程,線程少的話這不會是問題,而真實(shí)環(huán)境可能會開啟多個(gè)線程讓系統(tǒng)和程序達(dá)到最佳效率,當(dāng)線程數(shù)達(dá)到一定數(shù)量就會耗盡系統(tǒng)的CPU和內(nèi)存資源,也會造成GC頻繁收集和停頓,因?yàn)槊看蝿?chuàng)建和銷毀一個(gè)線程都是要消耗系統(tǒng)資源的,如果為每個(gè)任務(wù)都創(chuàng)建線程這無疑是一個(gè)很大的性能瓶頸。

所以,線程池中的線程復(fù)用極大節(jié)省了系統(tǒng)資源,當(dāng)線程一段時(shí)間不再有任務(wù)處理時(shí)它也會自動銷毀,而不會長駐內(nèi)存。

線程池核心類

在java.util.concurrent包中我們能找到線程池的定義,其中ThreadPoolExecutor是我們線程池核心類,首先看看線程池類的主要參數(shù)有哪些。

java高級應(yīng)用:線程池的全面講解(干貨)

corePoolSize:線程池的核心大小,也可以理解為最小的線程池大小。

maximumPoolSize:最大線程池大小。

keepAliveTime:空余線程存活時(shí)間,指的是超過corePoolSize的空余線程達(dá)到多長時(shí)間才進(jìn)行銷毀。

unit:銷毀時(shí)間單位。

workQueue:存儲等待執(zhí)行線程的工作隊(duì)列。

threadFactory:創(chuàng)建線程的工廠,一般用默認(rèn)即可。

handler:拒絕策略,當(dāng)工作隊(duì)列、線程池全已滿時(shí)如何拒絕新任務(wù),默認(rèn)拋出異常。

線程池工作流程

1、如果線程池中的線程小于corePoolSize時(shí)就會創(chuàng)建新線程直接執(zhí)行任務(wù)。

2、如果線程池中的線程大于corePoolSize時(shí)就會暫時(shí)把任務(wù)存儲到工作隊(duì)列workQueue中等待執(zhí)行。

3、如果工作隊(duì)列workQueue也滿時(shí):當(dāng)線程數(shù)小于最大線程池?cái)?shù)maximumPoolSize時(shí)就會創(chuàng)建新線程來處理,而線程數(shù)大于等于最大線程池?cái)?shù)maximumPoolSize時(shí)就會執(zhí)行拒絕策略。

線程池分類

Executors是jdk里面提供的創(chuàng)建線程池的工廠類,它默認(rèn)提供了4種常用的線程池應(yīng)用,而不必我們?nèi)ブ貜?fù)構(gòu)造。

newFixedThreadPool

固定線程池,核心線程數(shù)和最大線程數(shù)固定相等,而空閑存活時(shí)間為0毫秒,說明此參數(shù)也無意義,工作隊(duì)列為最大為Integer.MAX_VALUE大小的阻塞隊(duì)列。當(dāng)執(zhí)行任務(wù)時(shí),如果線程都很忙,就會丟到工作隊(duì)列等有空閑線程時(shí)再執(zhí)行,隊(duì)列滿就執(zhí)行默認(rèn)的拒絕策略。

java高級應(yīng)用:線程池的全面講解(干貨)

newCachedThreadPool

帶緩沖線程池,從構(gòu)造看核心線程數(shù)為0,最大線程數(shù)為Integer最大值大小,超過0個(gè)的空閑線程在60秒后銷毀,SynchronousQueue這是一個(gè)直接提交的隊(duì)列,意味著每個(gè)新任務(wù)都會有線程來執(zhí)行,如果線程池有可用線程則執(zhí)行任務(wù),沒有的話就創(chuàng)建一個(gè)來執(zhí)行,線程池中的線程數(shù)不確定,一般建議執(zhí)行速度較快較小的線程,不然這個(gè)最大線程池邊界過大容易造成內(nèi)存溢出。

java高級應(yīng)用:線程池的全面講解(干貨)

newSingleThreadExecutor

單線程線程池,核心線程數(shù)和最大線程數(shù)均為1,空閑線程存活0毫秒同樣無意思,意味著每次只執(zhí)行一個(gè)線程,多余的先存儲到工作隊(duì)列,一個(gè)一個(gè)執(zhí)行,保證了線程的順序執(zhí)行。

java高級應(yīng)用:線程池的全面講解(干貨)

newScheduledThreadPool

調(diào)度線程池,即按一定的周期執(zhí)行任務(wù),即定時(shí)任務(wù),對ThreadPoolExecutor進(jìn)行了包裝而已。

java高級應(yīng)用:線程池的全面講解(干貨)

拒絕策略AbortPolicy

簡單粗暴,直接拋出拒絕異常,這也是默認(rèn)的拒絕策略。

java高級應(yīng)用:線程池的全面講解(干貨)

java高級應(yīng)用:線程池的全面講解(干貨)

CallerRunsPolicy

如果線程池未關(guān)閉,則會在調(diào)用者線程中直接執(zhí)行新任務(wù),這會導(dǎo)致主線程提交線程性能變慢。

java高級應(yīng)用:線程池的全面講解(干貨)

DiscardPolicy

從方法看沒做任務(wù)操作,即表示不處理新任務(wù),即丟棄。

java高級應(yīng)用:線程池的全面講解(干貨)

DiscardOldestPolicy

拋棄最老的任務(wù),就是從隊(duì)列取出最老的任務(wù)然后放入新的任務(wù)進(jìn)行執(zhí)行。

java高級應(yīng)用:線程池的全面講解(干貨)

如何提交線程

如可以先隨便定義一個(gè)固定大小的線程池

ExecutorService es = Executors.newFixedThreadPool(3);

提交一個(gè)線程

es.submit(xxRunnble);es.execute(xxRunnble);submit和execute分別有什么區(qū)別呢?

execute沒有返回值,如果不需要知道線程的結(jié)果就使用execute方法,性能會好很多。

submit返回一個(gè)Future對象,如果想知道線程結(jié)果就使用submit提交,而且它能在主線程中通過Future的get方法捕獲線程中的異常。

如何關(guān)閉線程池

es.shutdown();

不再接受新的任務(wù),之前提交的任務(wù)等執(zhí)行結(jié)束再關(guān)閉線程池。

es.shutdownNow();

不再接受新的任務(wù),試圖停止池中的任務(wù)再關(guān)閉線程池,返回所有未處理的線程list列表。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 手机看片欧美 | 暖暖在线精品日本中文 | 国内精品久久久久久久aa护士 | www亚洲成人 | 欧美视频第一页 | 天天看片天天爽 | 久久久久久久综合色一本 | 精品一区二区三区视频在线观看 | 一级毛片在线不卡直接观看 | 毛片免费观看日本中文 | 国内精品免费一区二区三区 | 欧日韩美香蕉在线观看 | 国产成人在线视频免费观看 | 成人免费福利网站在线看 | 日韩 欧美 国产 师生 制服 | 一级毛片在线观看视频 | 性8sex亚洲区入口 | 在线国产一区 | 91精品国产色综合久久 | 在线欧美成人 | 欧美亚洲一区二区三区在线 | a级片免费 | 成人黄色免费 | 精品72久久久久久久中文字幕 | 日本理论片免费高清影视在线观看 | 韩国在线精品福利视频在线观看 | 美女张开双腿让男人桶 | 一级做a爱片特黄在线观看免费看 | 国产精品成人免费视频不卡 | 三级三级三级网站网址 | 欧美成人久久久免费播放 | 欧美日韩精品乱国产538 | 亚洲高清视频网站 | 中文在线com | 午夜手机看片 | 国产精品18久久久久久小说 | 性午夜| 国产日韩欧美一区二区三区综合 | 亚洲精品国产专区一区 | 国产片91人成在线观看 | 国产偷怕|