成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

四種常見線程池的原理,你學會了嗎?

開發 前端
newFixedThreadPool使用了無界的阻塞隊列LinkedBlockingQueue,如果線程獲取一個任務后,任務的執行時間比較長,會導致隊列的任務越積越多,導致機器內存使用不停飆升,最終導致OOM。

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

newCachedThreadPool (可緩存線程的線程池)

newSingleThreadExecutor (單線程的線程池)

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

前三種線程池的構造直接調用ThreadPoolExecutor的構造方法。

newSingleThreadExecutor

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

線程池特點:

核心線程數:1

最大線程數:1

阻塞隊列是無界隊列LinkedBlockingQueue,可能會導致OOM

keepAliveTime:0

工作流程:

1、提交任務

2、線程池是否有一條線程在,如果沒有,新建線程執行任務

3、如果有,將任務加到阻塞隊列

4、當前的唯一線程,從隊列取任務,執行完一個,再繼續,一個線程執行任務

適用場景:

適用于串行執行任務的場景,一個任務一個任務地執行

newFixedThreadPool

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

線程池特點:

核心線程數和最大線程數大小一樣;

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

阻塞隊列為無界隊列LinkedBlockingQueue,可能會導致OOM;


工作流程:

1、提交任務;

2、如果線程數少于核心線程,創建核心線程執行任務;

3、如果線程數等于核心線程,把任務添加到LinkedBlockingQueue阻塞隊列;

4、如果線程執行完任務,去阻塞隊列取任務,繼續執行。

適用場景:

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

newCachedThreadPool

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

線程池特點:

核心線程數為0;

最大線程數為Integer.MAX_VALUE,即無限大,可能會因為無線創建線程,導致OOM

阻塞隊列是SynchronousQueue

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

當提交任務速度大于處理任務的速度時,每次提交一個任務,就必然會創建一個線程。

極端情況下會創建過多的線程,耗盡CPU和內存資源。由于空閑60秒的線程會被終止,長時間保持空閑的CachedThreadPool不會占用任何資源。


工作流程:

提交任務;

因為沒有核心線程,所以任務會直接加到SynchronousQueue隊列;

判斷是否有空閑線程,如果有,就去取出任務執行;

如果沒有空閑線程,就新建一個線程執行;

執行完任務的線程,還可以存活60s,如果在這期間接到任務,就可以繼續活下去,否則被銷毀。

適用場景:

用于并發執行大量短期的小任務。

newScheduleThreadPool

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

線程池特點:

最大線程數為Integer.MAX_VALUE,也有OOM風險

阻塞隊列是DelayedWorkQueue

keepAliveTime為0

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

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

工作機制:

線程從DelayQueue中獲取已到期的ScheduledFutureTask(DelayQueue.take())。到期任務是指ScheduledFutureTask的time大于等于當前時間。

線程執行這個ScheduleFutureTask

線程修改ScheduledFutureTask的time變量為下次將要被執行的時間

線程把這個修改time之后的ScheduledFutureTask放回DelayQueue中(DelayQueue.add())。


使用場景:

周期性執行任務的場景,需要限制線程數量的場景。

使用無界隊列的線程池會導致什么問題:

例如newFixedThreadPool使用了無界的阻塞隊列LinkedBlockingQueue,如果線程獲取一個任務后,任務的執行時間比較長,會導致隊列的任務越積越多,導致機器內存使用不停飆升,最終導致OOM。

責任編輯:武曉燕 來源: 51CTO博客
相關推薦

2022-10-13 08:02:13

死鎖運算系統

2024-09-26 14:27:14

2025-01-16 08:38:34

2025-01-27 00:00:00

線程安全Java

2023-10-06 14:49:21

SentinelHystrixtimeout

2023-05-05 06:54:07

MySQL數據查詢

2023-03-30 08:26:31

DNSTCPUDP

2023-03-31 08:16:39

CDN網絡數據

2023-01-28 09:50:17

java多線程代碼

2021-01-28 09:58:46

線程池線程Thread

2024-03-12 08:37:32

asyncawaitJavaScript

2023-12-11 08:03:01

Java線程線程組

2022-07-08 09:27:48

CSSIFC模型

2024-01-19 08:25:38

死鎖Java通信

2023-01-10 08:43:15

定義DDD架構

2024-02-04 00:00:00

Effect數據組件

2023-07-26 13:11:21

ChatGPT平臺工具

2024-08-30 14:34:00

2022-12-09 09:21:10

分庫分表算法

2023-06-27 07:21:51

前端開發坑點
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲乱码一区二区三区在线观看 | 97免费在线观看视频 | 久久精品日| 国产高清在线 | 精品欧美一区二区久久久伦 | 一区二区蜜桃 | 亚洲精品久久久久久久不卡四虎 | 午夜精品一区 | 久久久久精 | 91精品国产色综合久久 | 欧美激情视频一区二区三区在线播放 | 在线观看视频一区二区三区 | 欧美精品久久久久 | 国内精品久久久久久影视8 最新黄色在线观看 | 久久久久久久久久久久久久国产 | 日日日日操 | 大香网伊人 | 国产精品一区二区三区四区 | 国产高清在线精品 | 日韩α片 | 国产目拍亚洲精品99久久精品 | 99re6在线 | 操射视频| 麻豆changesxxx国产 | 97色综合| 精品国产免费一区二区三区演员表 | 激情综合五月天 | 一区二区三区四区五区在线视频 | 91观看| 免费的av网站 | 日韩超碰 | 国产一区二区三区四区区 | 密色视频 | 日日操夜夜操天天操 | 久久综合一区 | 中文字幕 亚洲一区 | 男插女下体视频 | 成人国产精品久久 | 日韩1区2区 | 日韩成人免费av | 日本国产欧美 |