当任务数超过线程池的核心线程数时,如何让它不进入队列,而是直接启用最大线程数

线程池工作原理

当我们提交一个任务到线程池的时候,它的工作原理分为四步:

  1. 第一步,预热核心线程
  2. 第二步,把任务添加到阻塞队列
  3. 第三步,如果添加到阻塞队列失败,则创建非核心线程增加处理效率
  4. 第四步,如果非核心线程数达到了阈值,就触发拒绝策略

SynchronousQueue

所以,如果希望这个任务不进入队列,那么只需要去影响第二步的执行逻辑就行了。Java 中线程池提供的构造方法里面,有一个参数可以修改阻塞队列的类型。其中,就有一个阻塞队列叫 SynchronousQueue(如图), 这个队列不能存储任何元素。它的特性是,每生产一个任务,就必须要指派一个消费者来处理,否则就会阻塞生产者。

基于这个特性,只要把线程池的阻塞队列替换成 SynchronousQueue。就能够避免任务进入到阻塞队列,而是直接启动最大线程数去处理这个任务。

相关推荐
无所事事O_o几秒前
【监控报警体系建设】监控标准与最佳实践
java·架构·监控
gergul3 分钟前
python venv虚拟环境复制
linux·开发语言·python
LNN20225 分钟前
半导体设备上位机 Qt 实现计划
开发语言·数据库·qt
摇滚侠5 分钟前
Java 项目教程《黑马商城》OpenFeign 15 - 19
java·开发语言
小小小米粒6 分钟前
线程池创建模版
java
TE-茶叶蛋8 分钟前
`@interface` 解析
java
摇滚侠10 分钟前
Java 项目教程《黑马商城》微服务拆分 05 - 10
java·开发语言·微服务
虎头金猫12 分钟前
监控机不在被监控的机器上,Prometheus怎么跨网络把数据拉过来
运维·服务器·开发语言·网络·云原生·开源·prometheus
PPPPickup13 分钟前
实习日志5.7
java
_Evan_Yao13 分钟前
return 的迷途:try-catch-finally 中 return 的诡异顺序与 Spring 事务暗坑
java·后端·spring·mybatis