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

线程池工作原理

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

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

SynchronousQueue

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

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

相关推荐
上位机付工12 分钟前
上位机通信速度有多快?
开发语言·c#·上位机·plc
蔗理苦12 分钟前
2025-09-05 CSS4——浮动与定位
开发语言·前端·css·html·css3
给我个面子中不15 分钟前
JUC、JVM八股补充
java·开发语言·jvm
mask哥1 小时前
详解flink性能优化
java·大数据·微服务·性能优化·flink·kafka·stream
hqxstudying1 小时前
Kafka 深入研究:从架构革新到性能优化的全面解析
java·开发语言·微服务·kafka·springcloud
失散132 小时前
并发编程——17 CPU缓存架构详解&高性能内存队列Disruptor实战
java·缓存·架构·并发编程
only-qi7 小时前
146. LRU 缓存
java·算法·缓存
悟能不能悟7 小时前
js闭包问题
开发语言·前端·javascript
潼心1412o7 小时前
C语言(长期更新)第15讲 指针详解(五):习题实战
c语言·开发语言
xuxie138 小时前
SpringBoot文件下载(多文件以zip形式,单文件格式不变)
java·spring boot·后端