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

线程池工作原理

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

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

SynchronousQueue

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

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

相关推荐
heartbeat..7 小时前
Servlet 全面解析(JavaWeb 核心)
java·网络·后端·servlet
lingran__7 小时前
C语言自定义类型详解 (1.1w字版)
c语言·开发语言
vx_bisheyuange8 小时前
基于SpringBoot的疗养院管理系统
java·spring boot·后端
村口曹大爷8 小时前
JDK 24 正式发布:性能压轴,为下一代 LTS 铺平道路
java·开发语言
1.14(java)8 小时前
MySQL数据库操作全攻略
java·数据库·mysql
正远数智8 小时前
深度解析:SRM系统如何赋能采购库存协同
java·lowcode
青岛少儿编程-王老师8 小时前
CCF编程能力等级认证GESP—C++1级—20251227
java·c++·算法
ysdysyn9 小时前
C# Modbus RTU 多从站控制全攻略:一端口,双轴控制
开发语言·c#·mvvm·通讯·modbus rtu
hashiqimiya9 小时前
java程序的并发
java·开发语言·python
微露清风9 小时前
系统性学习C++进阶-第十四讲-二叉搜索树
开发语言·c++·学习