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

线程池工作原理

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

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

SynchronousQueue

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

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

相关推荐
刘个Java2 小时前
对接大疆上云api---实现直播效果
java
用户9545156811622 小时前
== 和 equals 区别及使用方法组件封装方法
java
hashiqimiya2 小时前
html的input的required
java·前端·html
起予者汝也2 小时前
Python基础入门
开发语言·python
一只叫煤球的猫2 小时前
从1996到2025——细说Java锁的30年进化史
java·后端·性能优化
努力努力再努力wz2 小时前
【Linux进阶系列】:线程(上)
java·linux·运维·服务器·数据结构·c++·redis
极客柒2 小时前
Unity 协程GC优化记录
java·unity·游戏引擎
我要去腾讯2 小时前
Springcloud核心组件之Sentinel详解
java·spring cloud·sentinel
czhc11400756632 小时前
Java117 最长公共前缀
java·数据结构·算法
芯联智造2 小时前
【stm32协议外设篇】- SU03T 智能语音模块
c语言·开发语言·stm32·单片机·嵌入式硬件