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

线程池工作原理

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

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

SynchronousQueue

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

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

相关推荐
IUGEI8 分钟前
【计算机网络】HTTP/3如何实现可靠传输?
java·网络·后端·网络协议·tcp/ip·计算机网络·http
0***1425 分钟前
JavaScript视频处理案例
开发语言·javascript·音视频
ceclar12334 分钟前
C#常用集合的使用
开发语言·windows·c#
z***I39440 分钟前
PHP Composer
开发语言·php·composer
u***u68544 分钟前
JavaGraphQL案例
java·spring boot·后端
1***81531 小时前
Swift在服务端开发的可能性探索
开发语言·ios·swift
2501_941879811 小时前
Python在微服务高并发异步流量控制与动态限流熔断架构中的实践
java·开发语言
zero13_小葵司1 小时前
JavaScript性能优化系列(八)弱网环境体验优化 - 8.2 离线支持:Service Worker实现基本离线功能
开发语言·javascript·性能优化
S***H2831 小时前
Swift在系统级应用中的开发
开发语言·ios·swift
REDcker1 小时前
C++ std::shared_ptr 线程安全性和最佳实践详解
java·jvm·c++