线程池原理最全详解:从概念到实现
创作时间:
作者:
@小白创作中心
线程池原理最全详解:从概念到实现
引用
CSDN
1.
https://blog.csdn.net/zhzjn/article/details/143191839
线程池是Java并发编程的核心技术之一,广泛应用于高并发场景中。本文将从线程池的基本概念出发,深入探讨其工作原理、实现机制以及使用注意事项,帮助读者全面理解这一重要知识点。
线程池概述
线程池(Thread Pool)是一种多线程管理技术,它维护了一组预先创建的线程,用来执行提交的任务。在 Java 中,线程池通过 Executor 接口进行管理,Executors 工具类提供了各种方便的线程池创建方法。
例如,创建一个固定大小的线程池:
ExecutorService fixedThreadPool = Executors.newFixedThreadPool(4);
通过使用线程池,系统可以避免频繁创建和销毁线程的开销,从而提高性能和响应速度。尤其在任务短小且频繁时,通过复用线程,可以避免大量的资源消耗。
线程池实现原理
线程池的实现原理,如下图所示:
主要包含以下步骤:
第一步:判断核心线程是否有空闲
当有新任务提交到线程池时,线程池会首先检查核心线程池中的线程(数量为 corePoolSize)。
int currentPoolSize = workerCount.get();
if (currentPoolSize < corePoolSize) {
if (addWorker(command, true)) // 创建核心线程执行任务
return;
}
如果核心线程数小于 corePoolSize,或者有核心线程处于空闲状态,线程池会直接创建一个新的核心线程来执行这个任务。
第二步:判断工作队列是否已满
如果核心线程都在执行任务,且线程数量已经达到 corePoolSize,则任务不会立即创建新的线程,而是进入任务队列。
// 第二步:尝试将任务添加到队列
if (workQueue.offer(command)) {
int recheck = workerCount.get();
if (recheck == 0) // 如果线程池空闲,启动一个核心线程
addWorker(null, false);
}
第三步:判断线程池的最大线程数
如果任务队列已满,且线程池中的线程数少于 maximumPoolSize。线程池会尝试创建一个新的非核心线程(即超出 corePoolSize 的线程),用于处理当前提交的任务。
// 第三步:如果队列满了,判断是否可以创建新的非核心线程
else if (!addWorker(command, false)) {
// 第四步:如果无法创建新的非核心线程,执行拒绝策略
reject(command);
}
第四步:拒绝策略
当任务队列已满,且线程池中的线程数已经达到 maximumPoolSize 时,线程池无法接纳更多任务,这时线程池会使用预设的饱和策略来处理这个任务。
// 第四步:如果无法创建新的非核心线程,执行拒绝策略
reject(command);
常见的饱和策略包括:
- AbortPolicy:默认策略,抛出 RejectedExecutionException 异常,通知提交任务的线程池已满;
- CallerRunsPolicy:让提交任务的线程自己执行这个任务,以减少新任务提交的压力;
- DiscardPolicy:直接丢弃当前提交的任务,不做任何处理;
- DiscardOldestPolicy:丢弃队列中最老的任务,然后尝试提交新任务。
线程池的注意事项
配置线程池时需要根据系统负载、CPU 核心数、和任务类型进行合理配置。例如:
- CPU 密集型任务,可以设置 corePoolSize 接近 CPU 核心数;
- I/O 密集型任务,可以设置较高的 corePoolSize,允许更多线程等待 I/O 操作。
阻塞队列的选择也很关键:
- 无界队列,适合任务处理速度较快、不会积压太多任务的场景;
- 有界队列,适用于任务量高的场景,通过限制队列长度防止任务过载。
热门推荐
妙峰山自然风景区游玩攻略:一座让人流连忘返的京郊胜地
如何正确保养平板电脑(保持平板电脑的长久使用和良好性能)
行李箱abs+pc材质好还是pc材质的好?行李箱买啥材质的耐摔耐划?
目前有哪些能够分析照片颜值给出打分的AI算法
产品需求如何找销售渠道
方向盘调紧的正确方法是什么?这种调紧方法会带来哪些变化?
微信联合八大博物馆发起表情包创作活动,带动博物馆“花式破圈”
农业中的蚜虫:有效管理策略
期货鸡蛋的重量标准如何制定?制定后的标准有何影响?
白蜡木的优缺点
如何撰写完美的求助邮件?实用指南与模板
笛子练多久能上台表演
心学问教育咨询,儿童情商培养:家长如何提升孩子的情绪智力?
发烧最快的退烧方法是什么
复盘2024的得与失 重温投资中最重要的三件小事
甘肃沙海绿洲民勤:节水从传统管控向数字管水跨越
新闻娱乐化的定义、影响及治理对策
L3+自动驾驶系统技术要求详解「GB/T 44721-2024」
遏制结核,从用对药开始
模块化编程:理论基础、设计原则与技术实现
Excel怎么做指数回归方程
一体化发展下,青浦从“圆梦地铁”到实现“轨交自由”
健身不盲选!4步找到你的“本命运动”,效果翻倍
口干舌燥的中医食疗方法
去眼袋去黑眼圈注意及护理事项有哪些
19个经典好用的职场破冰小游戏
从8.9分大降至6分,《白夜破晓》到底差在哪?观众的评价“一针见血”
换位思维:提升沟通效果的有效途径
大连十大赏樱胜地全攻略:从旅顺到市中心,尽享樱花之美
挑对花椒,让菜肴美味升级!购买优质花椒的实用指南!