www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 芯聞號(hào) > 充電吧
[導(dǎo)讀]線程池的優(yōu)點(diǎn):1.重用線程池的線程,避免因?yàn)榫€程的創(chuàng)建和銷毀所帶來的性能開銷;2.能有效的控制線程池的最大并發(fā)數(shù),避免大量的線程之間因互相搶占系統(tǒng)資源而導(dǎo)致的阻塞現(xiàn)象;3.能夠?qū)€程進(jìn)行簡(jiǎn)單的管理,并


線程池的優(yōu)點(diǎn):

1.重用線程池的線程,避免因?yàn)榫€程的創(chuàng)建和銷毀所帶來的性能開銷;

2.能有效的控制線程池的最大并發(fā)數(shù),避免大量的線程之間因互相搶占系統(tǒng)資源而導(dǎo)致的阻塞現(xiàn)象;

3.能夠?qū)€程進(jìn)行簡(jiǎn)單的管理,并提供定時(shí)執(zhí)行以及指定間隔循環(huán)執(zhí)行等功能;

Android 中的線程池來源于 Java 中的 Executor,Executor 是一個(gè)接口,真正的線程池實(shí)現(xiàn)為 ThreadPOOLExecutor。

ThreadPoolExecutor

ThreadPoolExecutor 是線程池的真正實(shí)現(xiàn),它的構(gòu)造方法提供了一系列參數(shù)來配置線程池:

public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue workQueue, ThreadFactory threadFactory) { this(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue, threadFactory, defaultHandler); }

corePoolSie

線程池的核心線程數(shù),默認(rèn)情況下,核心線程會(huì)在線程池中一直存活,即使它們處于閑置狀態(tài)。如果將 ThreadPoolExecutor 的 allowCoreThreadTimeOut 屬性設(shè)置為 true,那么閑置的核心線程在等待新任務(wù)到來時(shí)會(huì)有超時(shí)策略,這個(gè)事件間隔由keepAliveTime 所指定,當(dāng)?shù)却录^ keepAliveTime 所指定的時(shí)間,核心線程會(huì)被終止。

maximumPoolSize

線程池中所能容納的最大線程數(shù),當(dāng)活動(dòng)線程數(shù)達(dá)到這個(gè)數(shù)值后,后續(xù)的任務(wù)會(huì)被阻塞。

keepAliveTime

非核心線程閑置是的超時(shí)時(shí)長(zhǎng),超過這個(gè)時(shí)長(zhǎng),非核心線程就會(huì)被回收。如果將 ThreadPoolExecutor 的 allowCoreThreadTimeOut 屬性設(shè)置為 true,keepAliveTime 同樣會(huì)作用于核心線程。

unit

用于指定 keepAliveTime 參數(shù)的時(shí)間單位,這是一個(gè)枚舉,常用的有 TimeUnit.MILLISECONDS(毫秒)、TimeUnit.SECONDS(秒)以及TimeUnit.MINUTES(分鐘)等。

workQueue

線程池中的任務(wù)隊(duì)列,通過線程池的 execute 方法提交的 Runnable 對(duì)象會(huì)存儲(chǔ)在這個(gè)參數(shù)中。

threadFactory

線程工廠,為線程池創(chuàng)建新線程的功能。ThreadFactory 是一個(gè)接口,它只有一個(gè)方法: Thread newThread(Runnable r).

ThreadPoolExecutor 執(zhí)行任務(wù)時(shí)大致遵循如下規(guī)則:

如果線程池中的線程數(shù)量未達(dá)到核心線程的數(shù)量,那么會(huì)直接啟動(dòng)一個(gè)核心線程來執(zhí)行任務(wù)。

如果線程池中的線程數(shù)量已經(jīng)達(dá)到或者超過核心線程的數(shù)量,那么任務(wù)會(huì)直接插入到任務(wù)隊(duì)列中排隊(duì)等待執(zhí)行。

如果在步驟2中無法將任務(wù)插入到任務(wù)隊(duì)列里,這往往是由于任務(wù)隊(duì)列已滿,這個(gè)時(shí)候如果線程數(shù)量未達(dá)到線程池規(guī)定的最大值,那么會(huì)立刻啟動(dòng)一個(gè)非核心線程來執(zhí)行任務(wù)。

如果步驟3中線程數(shù)量已經(jīng)達(dá)到線程池規(guī)定的最大值,那么就拒絕執(zhí)行此任務(wù),ThreadPoolExecutor 會(huì)調(diào)用 RejectedExecutionHandler 的 rejectedExecution 方法來通知調(diào)用者。

線程池的分類

1. FixedThread

通過Executors 的 newFixedThreadPool 方法來創(chuàng)建,它是一種線程數(shù)量固定的線程池,當(dāng)線程處于空閑狀態(tài)時(shí),它們不會(huì)被回收,除非線程池被關(guān)閉了。

當(dāng)所有的線程都處于活動(dòng)狀態(tài)時(shí),新任務(wù)都會(huì)處于等待狀態(tài),直到有空閑線程。由于此線程池只有核心線程并且這些核心線程不會(huì)被回收,這意味著它能夠更加快速地響應(yīng)外界的請(qǐng)求。

2. CacheThreadPool

通過Executors 的 newCacheThreadPool 方法來創(chuàng)建,它是一種線程數(shù)量不定的線程池,它只有非核心線程,并且最大線程數(shù)為 Integer.MAX_VALUE。當(dāng)線程池中的線程都處于活動(dòng)狀態(tài)時(shí),線程池會(huì)創(chuàng)建新的線程來處理新任務(wù),否則就利用空閑的線程來處理新任務(wù)。線程池中的空閑線程超時(shí)時(shí)長(zhǎng)為60s,超過就會(huì)被回收,線程池的任務(wù)會(huì)立即執(zhí)行。所以這類線程池比較適合執(zhí)行大量的耗時(shí)較少的任務(wù)。當(dāng)整個(gè)線程池都處于閑置狀態(tài)時(shí),線程池中的線程都會(huì)超時(shí)而被停止,這個(gè)時(shí)候CacheThreadPool 之中實(shí)際上是沒有任何線程的,它幾乎是不占用任何系統(tǒng)資源的。

3. ScheduleThreadPool

通過Executors 的 ScheduleThreadPool 方法來創(chuàng)建,它的核心線程數(shù)是固定的,而非核心線程數(shù)是沒有限制的,并且當(dāng)非核心線程閑置時(shí)會(huì)被立即回收。ScheduleThreadPool 這類線程池主要用來執(zhí)行定時(shí)任務(wù)和具有固定周期的重復(fù)任務(wù)。

4. SingleThreadExecutor

通過Executors 的 SingleThreadExecutor 方法來創(chuàng)建,這類線程池內(nèi)部只有一個(gè)核心線程,它確保所有的任務(wù)都在同一個(gè)線程中按順序執(zhí)行。SingleThreadExecutor 的意義在于統(tǒng)一所有的外界任務(wù)到一個(gè)線程中,這使得在這些任務(wù)之間不需要處理線程同步的問題。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉