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

线程池工作原理

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

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

SynchronousQueue

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

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

相关推荐
2401_874732531 分钟前
C++中的策略模式进阶
开发语言·c++·算法
steins_甲乙6 分钟前
C# 通过共享内存与 C++ 宿主协同捕获软件窗口
开发语言·c++·c#·内存共享
章鱼丸-22 分钟前
DAY34 GPU 训练与类的 call 方法
开发语言·python
2501_9454235424 分钟前
C++跨平台开发实战
开发语言·c++·算法
英俊潇洒美少年26 分钟前
函数组件(Hooks)的 **10 大优点**
开发语言·javascript·react.js
Oueii27 分钟前
分布式系统监控工具
开发语言·c++·算法
小陈工34 分钟前
2026年3月24日技术资讯洞察:边缘AI商业化,Java26正式发布与开源大模型成本革命
java·运维·开发语言·人工智能·python·容器·开源
haibindev39 分钟前
把近5万个源文件喂给AI之前,我先做了一件事
java·前端·c++·ai编程·代码审计·架构分析
yymboss1 小时前
【JavaEE】Spring Boot 项目创建
java·spring boot·java-ee
方安乐1 小时前
Javascript工具库:classnames
开发语言·javascript·ecmascript