線程池—【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 什麼是線程池
- 池的概念 :用來放一堆相同東西的容器。eg:水池(裝的全是水);
- 大白話線程池,顧名思義:裝的全是線程;
- 百度官方說法:
- 類比:資料庫連接配接池;
- 類圖:
- 線程池構造方法參數意義:
【二】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