线程池的工作原理


程序员的公众号:源1024,获取更多资料, 无加密无套路!

最近整理了一份大厂面试资料《史上最全大厂面试题》,Springboot、微服务、算法、数据结构、Zookeeper、Mybatis、Dubbo、linux、Kafka、Elasticsearch、数据库等等
获取方式: 关注公众号并回复 666 领取,更多内容持续奉上


线程池主要是利用线程的复用性,将任务的提交和线程的创建、管理、执行分离,线程池来统一管理和调度,减少了创建和销毁线程的开销,提高了系统的效率。

线程池的工作原理

1、任务提交时,线程池首先检查当前线程数是否小于核心线程数,如果小于,则新建一个线程来执行任务。
2、如果当前线程数已经达到核心线程数,而且队列中没有正在执行的任务时,则将任务放入队列中等待执行。
3、如果队列已满,且线程池中的线程数量未达到最大线程数,则新建线程来执行任务。
4、如果队列已满,且线程池中的线程数量达到最大线程数,则根据拒绝策略来处理无法执行的任务。

线程池的参数:

  1. 核心线程数(corePoolSize) 这是线程池中一直保持活动状态的最小线程数量。核心线程在空闲时不会被销毁,除非启用了 allowCoreThreadTimeOut 选项。核心线程数的设置直接影响了线程池的基本并发度。

  2. 最大线程数(maximumPoolSize) 当任务提交到线程池时,首先会尝试使用已有的空闲线程来处理,如果没有空闲线程则根据需要创建新线程。最大线程数限制了线程池可以创建的最大线程数量,过高的设置可能会导致资源消耗过多。

  3. keepAliveTime 和 TimeUnit 这两个参数用于控制空闲线程的存活时间。如果线程在空闲时间超过 keepAliveTime 指定的时间段,它将被终止并从线程池中移除。合理的设置可以降低线程池的维护成本。

  4. 工作队列(workQueue) 工作队列用于存储等待执行的任务。不同类型的工作队列(如有界队列或无界队列)对线程池的性能有一定影响。有界队列可以避免无限制的任务积压,但可能导致任务丢失,而无界队列可能会占用更多的内存。

实际工作中,要根据我们的实际情况,通过合理配置和调整参数,来优化线程池的性能,确保高效地处理任务并避免资源浪费。

相关推荐
会飞的架狗师30 分钟前
【Spring Cloud Gateway】Nacos整合遇坑记:503 Service Unavailable
java·开发语言
重生之后端学习2 小时前
02-前端Web开发(JS+Vue+Ajax)
java·开发语言·前端·javascript·vue.js
字节源流8 小时前
关于maven的依赖下不下来的问题
java·maven
pjx9878 小时前
服务间的“握手”:OpenFeign声明式调用与客户端负载均衡
java·运维·spring·负载均衡
prinrf('千寻)9 小时前
MyBatis-Plus 的 updateById 方法不更新 null 值属性的问题
java·开发语言·mybatis
老华带你飞9 小时前
实习记录小程序|基于SSM+Vue的实习记录小程序设计与实现(源码+数据库+文档)
java·数据库·spring boot·小程序·论文·毕设·实习记录小程序
在未来等你9 小时前
互联网大厂Java求职面试:AI与大模型应用集成及云原生挑战
java·微服务·ai·kubernetes·大模型·embedding·spring ai
源码技术栈9 小时前
SaaS基于云计算、大数据的Java云HIS平台信息化系统源码
java·大数据·云计算·云his·his系统·云医院·区域his
编程、小哥哥10 小时前
互联网大厂Java面试:从Spring Boot到微服务架构的技术深挖
java·spring boot·redis·微服务·prometheus·面试技巧
揽你·入怀10 小时前
数据结构:ArrayList简单实现与常见操作实例详解
java·开发语言