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

线程池工作原理

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

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

SynchronousQueue

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

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

相关推荐
是垚不是土10 小时前
基于DDNS-Go动态域名解析配置:实现多网络线路冗余切换方案
运维·开发语言·网络·阿里云·golang·运维开发
@大迁世界10 小时前
JavaScript 框架的终结
开发语言·前端·javascript·ecmascript
天远云服10 小时前
Go 语言实战:构建高并发天远“全国自然人人脸比对 V3”微服务网关
java·大数据·微服务·golang
catchadmin10 小时前
PHP True Async 最近进展以及背后的争议
开发语言·php
PPPPickup10 小时前
easychat项目复盘---管理端系统设置
java·开发语言·前端
挖矿大亨10 小时前
C++中的this指针
java·开发语言·c++
sheji341610 小时前
【开题答辩全过程】以 共享单车管理系统为例,包含答辩的问题和答案
java
姜糖编程日记10 小时前
C++——初识(2)
开发语言·前端·c++
ECT-OS-JiuHuaShan10 小时前
麻烦是第一推动力,不厌其烦就是负熵流
开发语言·人工智能·数学建模·学习方法·量子计算
北北~Simple10 小时前
接口调不通的情况
java