Java線程池的總結

Java線程池總結

線程池的好處

  1. 降低資源消耗
  2. 提高響應速度
  3. 提高線程的可管理性

線程池相關的具體參數

  1. corePoolSize
    • 線程池的核心線程數。在沒有設置 allowCoreThreadTimeOut 為 true 的情況下,核心線程會在線程池中一直存活,即使處于閑置狀態。
  2. maximumPoolSize
    • 線程池所能容納的最大線程數。當活動線程到達這個數值后,后續任務將會根據RejectedExecutionHandler 來進行拒絕策略處理。
  3. keepAliveTime
    • 非核心線程閑置的超時時長。超過該時長,非核心線程就會被回收。
    • 若線程池通過allowCoreThreadTimeOut()方法設置allowCoreThreadTimeOut屬性為True,則該時長同樣會作用于核心線程,AsyncTask配置的線程池就是這樣設置的。
  4. unit
    • keepAliveTime時長對應的單位。
  5. workQueue
    • 線程池中的任務隊列,通過線程池的execute()方法提交的Runnable對象會存儲在該隊列中。
  6. ThreadFactory
    • 線程工廠,為線程池提供創建新線程的功能。通過自定義,做一些自定義線程名的操作。
  7. RejectedExecutionHandler
    • 當任務無法執行時(超過線程最大容量maximum并且workQueue已經被排滿了)的處理策略。
    • 四種拒絕類型
      • ThreadPoolExecutor.AbortPolicy : 當線程池中的數量等于最大線程數時拋 java.util.concurrent.RejectedExecutionException 異常,涉及到該異常的任務也不會被執行,線程池默認的拒絕策略就是該策略。
      • ThreadPoolExecutor.DiscardPolicy() : 當線程池中的數量等于最大線程數時,默默丟棄不能執行的新加任務,不報任何異常
      • ThreadPoolExecutor.CallerRunsPolicy() : 當線程池中的數量等于最大線程數時,重試添加當前的任務;它會自動重復調用execute()方法。
      • ThreadPoolExecutor.DiscardOldestPolicy() : 當線程池中的數量等于最大線程數時,拋棄線程池中工作隊列頭部的任務(即等待時間最久的任務),并執行新傳入的任務。

線程池執行任務的順序

  1. 當線程數小于核心線程數時,創建線程,并處理請求
  2. 當線程數大于等于核心線程數時,且任務隊列未滿時,將任務放入任務隊列,隨著線程池中核心線程們不斷執行任務,只要線程池中有空閑的核心線程,線程池就從任務隊列中取任務并處理
  3. 當線程數大于等于核心線程數時,且任務隊列已滿時
    1. 若線程數小于最大線程數,創建線程
    2. 若線程數等于最大線程數,拋出異常,拒絕任務

newCachedThreadPool

  1. 具有緩存性質的線程池,線程可重復利用
  2. 線程最大空閑時間60s
  3. 沒有最大線程數限制
  4. 適用于任務耗時短,數量大
  5. 等待隊列是沒有容量的
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class CachedThreadPoolTest {
   public static void main(String[] args) {
       ExecutorService cachedThreadPool = Executors.newCachedThreadPool();
       for (int i = 0; i < 10; i++) {
           final int index = i;
//            try {
//                Thread.sleep(1000);
//            } catch (InterruptedException e) {
//                e.printStackTrace();
//            }

           Runnable task = new Runnable() {
               public void run() {
                   System.out.println(Thread.currentThread().getName() + ">>" + index);
               }
           };

           cachedThreadPool.execute(task);
       }
   }
}

newFixedThreadPool

  1. 具有固定數量的線程池
  2. 核心線程數等于最大線程數
  3. 線程最大空閑時間0
  4. 執行完即銷毀
  5. 超出最大線程數進行等待
  6. 高并發下控制性能
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class FixedThreadPoolTest {
    public static void main(String[] args) {
        System.out.println(Runtime.getRuntime().availableProcessors());
        ExecutorService fixedThreadPool = Executors.newFixedThreadPool(8);
        for (int i = 0; i < 10; i++) {
            final int index = i;
            fixedThreadPool.execute(new Runnable() {
                public void run() {
                    try {
                        System.out.println(Thread.currentThread().getName() + ">>" + index);
                        Thread.sleep(2000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            });
        }
    }
}

newScheduledThreadPool

  1. 具有時間調度特性
  2. 必須初始化核心線程數
  3. 底層使用DelayWorkQueue實現延遲特性

newSingleThreadPool

  1. 核心線程數與最大線程數為1
  2. 用于不需要并發順序執行

參考鏈接

http://gudong.name/2017/05/03/thread-pool-intro.html

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,182評論 6 543
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,489評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,290評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,776評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,510評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,866評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,860評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,036評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,585評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,331評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,536評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,058評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,754評論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,154評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,469評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,273評論 3 399
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,505評論 2 379

推薦閱讀更多精彩內容

  • 文章摘要:在業務系統中,線程池框架技術一直是用來解決多線程并發的一種有效方法。 在JDK中,J.U.C并發包下的T...
    癲狂俠閱讀 2,110評論 2 21
  • 為什么使用線程池 當我們在使用線程時,如果每次需要一個線程時都去創建一個線程,這樣實現起來很簡單,但是會有一個問題...
    閩越布衣閱讀 4,303評論 10 45
  • 今天開始第一天語音記錄。熬夜寫完了師父新店開業賀詞。早上到了將近8點鐘才起床。一杯麥片就當是早餐了。幫胤峰搬東西差...
    夕魄閱讀 148評論 0 0
  • 在我眼里 你比楊貴妃更有魅力 你比西施還美 你就是仙女下凡 古靈精怪 全世界我只愛你 就愛你一個 非你不娶 說多少...
    照亮Br閱讀 176評論 0 0
  • BlockCanary BlockCanary是markzhai同學的一個很實用的作品, 能檢測到主線程的卡頓, ...
    常強兒閱讀 16,415評論 2 9