JAVA中的线程池说明二

系列文章

JAVA中的线程池说明一

JAVA中的线程池说明二

目录

1.引入

2.参数解释

3.标准库中提供的四个拒绝策略


1.引入

  • java.util.concurrent 这个包里面放的很多类都是和并发编程(多线程编程)密切相关,这个包简称JUC;
  • 今天我们主要来了解Java线程池的相关知识。

2.参数解释

在这里,我们主要讲述第四个构造方法,其他方法与其类似,不再赘述。

|---------------------------------------|----------------------------------|
| 参数 | 解释 |
| int corePoolSize | 核心线程数 |
| int maximumPoolSize | 最大线程数 |
| long keepAliveTime | 描述了临时工可以摸鱼的最大时间 |
| TimeUnit unit | 时间单位(ms,s,min) |
| BlockingQueue<Runnable> workQueue ​ | 线程池任务队列 |
| ThreadFactory threadFactory ​ | 用于创建线程,线程池是需要创建线程的 |
| RejectedExecutionHandler handler ​ | 描述了线程池的"拒绝策略",即如果线程池任务队列已满,该如何处理 |

ThreadPoolExecutor 相当于将线程分为两类:

  1. 一类是正式员工(核心线程)

  2. 一类是临时工/实习生(非核心线程)

这两者之和等于最大线程数。

它允许正式员工在空闲时休息,但不允许临时工/实习生在空闲时休息太久,如果临时工/实习生长时间没有任务可做,它们将被销毁。整体策略是保证核心线程的稳定运行,同时根据需要动态调整非核心线程的数量。

3.标准库中提供的四个拒绝策略

详情

|----------------------------------------|---------------------------------|
| 名称 | 解释 |
| ThreadPoolExecutor.AbortPolicy | 如果任务较多,队列已满,抛出异常 |
| ThreadPoolExecutor.CallerRunsPolicy | 如果任务较多,队列已满,多出的任务,哪个线程添加,哪个线程处理 |
| ThreadPoolExecutor.DiscardOldestPolicy | 如果任务较多,队列已满,丢弃最早的任务 |
| ThreadPoolExecutor.DiscardPolicy | 如果任务较多,队列已满,丢弃最新任务 |

以上就是Java多线程的补充说明。

相关推荐
xyq20246 小时前
服务定位器模式
开发语言
努力努力再努力wz6 小时前
【MySQL入门系列】掌握表数据的 CRUD:DML 核心语法与执行逻辑解析
android·开发语言·数据结构·数据库·c++·b树·mysql
xiaoye-duck6 小时前
【C++:异常】C++ 异常讲解指南:从理论到实践,深入理解栈展开和优雅处理程序错误
开发语言·c++·异常
SarL EMEN6 小时前
海康威视摄像头ISUP(原EHOME协议) 摄像头实时预览springboot 版本java实现,并可以在浏览器vue前端播放(附带源码)
java·前端·spring boot
qq_452396236 小时前
【工程实战】第八篇:报告美学 —— Allure 深度定制:让 Bug 定位精准到秒
开发语言·python·bug
考虑考虑6 小时前
图片居中
java·后端·java ee
Zqrnja7 小时前
PTA 2026天体选拔赛(多校联赛)L2-1 仪式网络(C++ 含代码解释)
开发语言·c++
llm大模型算法工程师weng7 小时前
负载均衡做什么?nginx是什么
运维·开发语言·nginx·负载均衡
有梦想的攻城狮7 小时前
java中的EnumSet使用详解
java·set·bitset·enumset
逆境不可逃7 小时前
【后端新手谈13】VO、BO、PO、DO、DTO:Java 分层开发的 5 大核心数据对象
java·开发语言