欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java?Executors常用線程池

 更新時間:2023年08月29日 11:19:59   作者:jacheut  
這篇文章主要為大家介紹了java?Executors中提供的幾種常用的線程池使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

newFixedThreadPool 固定數(shù)目線程的線程池

public static ExecutorService newFixedThreadPool(int nThreads) {
    return new ThreadPoolExecutor(nThreads, nThreads,
                                  0L, TimeUnit.MILLISECONDS,
                                  new LinkedBlockingQueue<Runnable>());
}

線程池特點

核心線程數(shù)和最大線程數(shù)大小一樣

沒有所謂的非空閑時間,即keepAliveTime為0

阻塞隊列為無界隊列LinkedBlockingQueue

工作機制

  • 提交任務(wù)
  • 如果線程數(shù)少于核心線程,創(chuàng)建核心線程執(zhí)行任務(wù)
  • 如果線程數(shù)等于核心線程,把任務(wù)添加到LinkedBlockingQueue阻塞隊列
  • 如果線程執(zhí)行完任務(wù),去阻塞隊列取任務(wù),繼續(xù)執(zhí)行。

使用無界隊列的線程池會導(dǎo)致內(nèi)存飆升嗎?

會的,newFixedThreadPool使用了無界的阻塞隊列LinkedBlockingQueue,如果線程獲取一個任務(wù)后,任務(wù)的執(zhí)行時間比較長,會導(dǎo)致隊列的任務(wù)越積越多,導(dǎo)致機器內(nèi)存使用不停飆升,最終導(dǎo)致OOM。

使用場景

FixedThreadPool 適用于處理CPU密集型的任務(wù),確保CPU在長期被工作線程使用的情況下,盡可能的少的分配線程,即適用執(zhí)行長期的任務(wù)。

newCachedThreadPool 可緩存線程的線程池

public static ExecutorService newCachedThreadPool(ThreadFactory threadFactory) {
    return new ThreadPoolExecutor(0, Integer.MAX_VALUE,
                                  60L, TimeUnit.SECONDS,
                                  new SynchronousQueue<Runnable>(),
                                  threadFactory);
}

線程池特點

核心線程數(shù)為0

最大線程數(shù)為Integer.MAX_VALUE

阻塞隊列是SynchronousQueue

非核心線程空閑存活時間為60秒

當(dāng)提交任務(wù)的速度大于處理任務(wù)的速度時,每次提交一個任務(wù),就必然會創(chuàng)建一個線程。極端情況下會創(chuàng)建過多的線程,耗盡CPU和內(nèi)存資源。由于空閑 60 秒的線程會被終止,長時間保持空閑的 CachedThreadPool 不會占用任何資源。

工作機制

  • 提交任務(wù)
  • 因為沒有核心線程,所以任務(wù)直接加到SynchronousQueue隊列。
  • 判斷是否有空閑線程,如果有,就去取出任務(wù)執(zhí)行。
  • 如果沒有空閑線程,就新建一個線程執(zhí)行。
  • 執(zhí)行完任務(wù)的線程,還可以存活60秒,如果在這期間,接到任務(wù),可以繼續(xù)活下去;否則,被銷毀。

使用場景

用于并發(fā)執(zhí)行大量短期的小任務(wù)。

newSingleThreadExecutor 單線程的線程池

public static ExecutorService newSingleThreadExecutor() {
    return new FinalizableDelegatedExecutorService
        (new ThreadPoolExecutor(1, 1,
                                0L, TimeUnit.MILLISECONDS,
                                new LinkedBlockingQueue<Runnable>()));
}

線程池特點

核心線程數(shù)為1

最大線程數(shù)也為1

阻塞隊列是LinkedBlockingQueue

keepAliveTime為0

工作機制

  • 提交任務(wù)
  • 線程池是否有一條線程在,如果沒有,新建線程執(zhí)行任務(wù)
  • 如果有,將任務(wù)加到阻塞隊列
  • 當(dāng)前的唯一線程,從隊列取任務(wù),執(zhí)行完一個,再繼續(xù)取,一個人(一條線程)夜以繼日地干活。

使用場景

適用于串行執(zhí)行任務(wù)的場景,一個任務(wù)一個任務(wù)地執(zhí)行。

newScheduledThreadPool 定時及周期執(zhí)行的線程池

public ScheduledThreadPoolExecutor(int corePoolSize) {
    super(corePoolSize, Integer.MAX_VALUE, 0, NANOSECONDS,
          new DelayedWorkQueue());
}

線程池特點

最大線程數(shù)為Integer.MAX_VALUE

阻塞隊列是DelayedWorkQueue

keepAliveTime為0

scheduleAtFixedRate() :按某種速率周期執(zhí)行

scheduleWithFixedDelay():在某個延遲后執(zhí)行

工作機制

  • 添加一個任務(wù)
  • 線程池中的線程從 DelayQueue 中取任務(wù)
  • 線程從 DelayQueue 中獲取 time 大于等于當(dāng)前時間的task
  • 執(zhí)行完后修改這個 task 的 time 為下次被執(zhí)行的時間
  • 這個 task 放回DelayQueue隊列中

使用場景

周期性執(zhí)行任務(wù)的場景,需要限制線程數(shù)量的場景

以上就是java Executors常用線程池的詳細內(nèi)容,更多關(guān)于java Executors線程池的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Java實現(xiàn)隨機生成大小寫混合的卡密的步驟

    Java實現(xiàn)隨機生成大小寫混合的卡密的步驟

    在現(xiàn)代軟件開發(fā)中,生成隨機卡密是一個常見的需求,尤其是在需要為用戶生成唯一識別碼或安全令牌的場景中,卡密通常由數(shù)字和字母組成,有時還會包含特殊字符,本文通過代碼講解的非常詳細,需要的朋友可以參考下
    2024-11-11
  • Java8之Stream流代替For循環(huán)操作

    Java8之Stream流代替For循環(huán)操作

    這篇文章主要介紹了Java8之Stream流代替For循環(huán)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • 通過反射注解批量插入數(shù)據(jù)到DB的實現(xiàn)方法

    通過反射注解批量插入數(shù)據(jù)到DB的實現(xiàn)方法

    今天小編就為大家分享一篇關(guān)于通過反射注解批量插入數(shù)據(jù)到DB的實現(xiàn)方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • 解析如何用兩個棧來實現(xiàn)隊列的方法

    解析如何用兩個棧來實現(xiàn)隊列的方法

    本篇文章是對如何用兩個棧實現(xiàn)隊列的方法進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • Java SE使用數(shù)組實現(xiàn)高速數(shù)字轉(zhuǎn)換功能

    Java SE使用數(shù)組實現(xiàn)高速數(shù)字轉(zhuǎn)換功能

    隨著大數(shù)據(jù)時代的到來,數(shù)字轉(zhuǎn)換功能變得越來越重要,在Java開發(fā)中,數(shù)字轉(zhuǎn)換功能也是經(jīng)常用到的,下面我們就來學(xué)習(xí)一下如何使用Java SE數(shù)組實現(xiàn)高速的數(shù)字轉(zhuǎn)換功能吧
    2023-11-11
  • java實現(xiàn)頁面多查詢條件必選的統(tǒng)一處理思路

    java實現(xiàn)頁面多查詢條件必選的統(tǒng)一處理思路

    這篇文章主要為大家介紹了java實現(xiàn)頁面多查詢條件必選的統(tǒng)一處理思路詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • Java獲取支付寶OpenID的實現(xiàn)方法

    Java獲取支付寶OpenID的實現(xiàn)方法

    在Java中,通過支付寶開放平臺API可以獲取用戶的OpenID,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-09-09
  • mybatis類型轉(zhuǎn)換器如何實現(xiàn)數(shù)據(jù)加解密

    mybatis類型轉(zhuǎn)換器如何實現(xiàn)數(shù)據(jù)加解密

    這篇文章主要介紹了mybatis類型轉(zhuǎn)換器如何實現(xiàn)數(shù)據(jù)加解密,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • SpringSecurity身份認證原理解析

    SpringSecurity身份認證原理解析

    這篇文章主要介紹了SpringSecurity身份認證原理解析,身份認證時用戶名和密碼被過濾器獲取到,封裝成 Authentication ,通常情況下是 UsernamePasswordAuthenticationToken 這個實現(xiàn)類,需要的朋友可以參考下
    2023-09-09
  • springboot中的css樣式顯示不出了的幾種情況

    springboot中的css樣式顯示不出了的幾種情況

    這篇文章主要介紹了springboot中的css樣式顯示不出了的幾種情況,具有很好的的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10

最新評論