天天看點

線程池—【ThreadPool】—掃盲篇

線程池—【ThreadPool】—掃盲篇

    • 【一】What is the ThreadPool 什麼是線程池
    • 【二】How can we use the ThreadPool 我們如何使用它
    • 1.核心數=最大數 線程無緩存時間 使用LinkedBlockingQueue作為阻塞工作隊列的單線程執行器的線程池
    • 2.核心數=最大數=n 線程無緩存時間 使用LinkedBlockingQueue作為阻塞工作隊列的固定線程執行器的線程池
    • 3.核心數=0,最大數=Interger.MAX_VALUE 線程緩存時間=60S 使用SynchronousQueue作為阻塞工作隊列的緩存線程執行器的線程池
    • 4.核心數=n,最大數=Interger.MAX_VALUE 線程無緩存時間 使用DelayedWorkQueue作為阻塞工作隊列的定時任務的線程執行器的線程池
    • 【三】Why use the ThreadPool 為什麼使用線程池
    • 1.降低資源消耗:通過重複利用已建立的線程降低線程建立和銷毀造成的消耗。
    • 2.提高相應速度:當任務到達時,任務可以不需要等到線程建立就能立即執行。
    • 3.提高線程的可管理性:線程是稀缺資源,如果無限制地建立,不僅會消耗系統資源,還會降低系統的穩定性,使用線程池可以進行統一配置設定,調優和監控。

大家好! 寫這篇部落格的目的是分析一下線程池的使用,做到知其然知其是以然。

The real target is that I was asked the ThreadPool usage in the interview. And I cann’t answer it.

真正目的是因為在面試中被問到線程池的使用,我沒有很好的答上來。

【一】What is the ThreadPool 什麼是線程池

  1. 池的概念 :用來放一堆相同東西的容器。eg:水池(裝的全是水);
    線程池—【ThreadPool】—掃盲篇
  2. 大白話線程池,顧名思義:裝的全是線程;
  3. 百度官方說法:
    線程池—【ThreadPool】—掃盲篇
  4. 類比:資料庫連接配接池;
  5. 類圖:
    線程池—【ThreadPool】—掃盲篇
  6. 線程池構造方法參數意義:
    線程池—【ThreadPool】—掃盲篇

【二】How can we use the ThreadPool 我們如何使用它

1.核心數=最大數 線程無緩存時間 使用LinkedBlockingQueue作為阻塞工作隊列的單線程執行器的線程池

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

2.核心數=最大數=n 線程無緩存時間 使用LinkedBlockingQueue作為阻塞工作隊列的固定線程執行器的線程池

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

3.核心數=0,最大數=Interger.MAX_VALUE 線程緩存時間=60S 使用SynchronousQueue作為阻塞工作隊列的緩存線程執行器的線程池

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

4.核心數=n,最大數=Interger.MAX_VALUE 線程無緩存時間 使用DelayedWorkQueue作為阻塞工作隊列的定時任務的線程執行器的線程池

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

【三】Why use the ThreadPool 為什麼使用線程池

1.降低資源消耗:通過重複利用已建立的線程降低線程建立和銷毀造成的消耗。

2.提高相應速度:當任務到達時,任務可以不需要等到線程建立就能立即執行。

3.提高線程的可管理性:線程是稀缺資源,如果無限制地建立,不僅會消耗系統資源,還會降低系統的穩定性,使用線程池可以進行統一配置設定,調優和監控。

參考資料:

《Java并發程式設計的技術》

JDK8源碼:Executor

JDK8源碼:ExecutorService

JDK8源碼:AbstractExecutorService

JDK8源碼:ThreadPoolExecutor

JDK8源碼:Executors

JDK8源碼:ScheduledThreadPoolExecutor

繼續閱讀