线程池原理最全详解:从概念到实现
创作时间:
作者:
@小白创作中心
线程池原理最全详解:从概念到实现
引用
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 操作。
阻塞队列的选择也很关键:
- 无界队列,适合任务处理速度较快、不会积压太多任务的场景;
- 有界队列,适用于任务量高的场景,通过限制队列长度防止任务过载。
热门推荐
金錢樹葉片變黃怎麼辦?專家教你3個技巧,輕鬆拯救你的搖錢樹
鼓膜内陷是什么病症状
如何高效查户口的步骤与注意事项详解
地皮菜:田野里的养生小精灵
消化道穿孔:身体里的“漏洞”危机
2024年全球TOP10集装箱港口出炉:出现新面孔
如何实现基金的灵活转换?基金转换的操作要点有哪些?
如何合理购买指数收益产品?这种购买方式有哪些选择标准?
揭秘电源变压器功率计算:轻松掌握,不再迷茫!
十年后执业药师前景分析:机遇与挑战并存
恋爱期间的转账,分手后能否要求对方返还?
车损肇事逃逸,交警如何处理?从现场勘查到法律处罚,一文全了解
30岁的女人为什么说猛如虎?猛就猛在五方面,来了解一下
染发基础操作技巧与注意事项
从反叛者到音乐大师:小约翰·施特劳斯的圆舞曲传奇
怎样卸载手机桌面上不想要的软件
医生叮嘱:身上出现这三种痣,癌变系数“飙升”!建议留心观察!
银行定期存款的利率在不同银行之间差异大吗?
2025考研:DeepSeek辣评17所985护理院校,你会选择哪所?
灭火器充装规定
美的电压力锅使用说明书(美的电高压锅的正确用法)
视频录屏取证的使用步骤和注意事项
数据驱动的5G网络切片规模和规划模型:具有预测和“假设”分析功能
典范院校案例:考研复试几乎不刷人的学校
古典健美:回归20世纪初的自然健美训练方法
科创板只需开通权限 50万资产和2年经验如何认定?
“姿势不对,起来重睡”:中医带你躺赢人生!
屈光参差的配镜矫正原则是
日本|从福冈到熊本的交通方式:完整指南与费用分析
鼓膜内陷可以自己恢复吗