ThreadPoolExecutor的内部类Worker详细解析
一、定义
ThreadPoolExecutor 的内部类 Worker 是线程池的核心实现之一,它封装了线程和任务,并负责执行任务。Worker 类继承自 AbstractQueuedSynchronizer(AQS),
并实现了 Runnable 接口。通过 Worker,线程池能够高效地管理线程的生命周期和任务的执行
1、Worker 类的设计目的
Worker 类的主要作用是:
1、封装线程和任务:将线程和任务绑定在一起,确保任务能够被正确执行。
2、管理线程的生命周期:通过 Worker,线程池可以控制线程的创建、执行和销毁。
3、实现任务的执行逻辑:Worker 的 run 方法会从任务队列中获取任务并执行
2、Worker 类的核心字段
Worker 类包含以下核心字段:
thread:Worker 封装的线程对象,用于执行任务。
firstTask:Worker 的初始任务。如果为 null,线程会从任务队列中获取任务。
completedTasks:记录 Worker 完成的任务数量。
3、构造函数
Worker 的构造函数用于初始化线程和任务:
setState(-1):将 AQS 的状态设置为 -1,防止线程在启动前被中断。
firstTask:传入的初始任务。
thread:通过线程工厂创建的新线程,Worker 本身作为 Runnable 传递给线程。
4、常用方法
4.1、run 方法
Worker 的 run 方法是线程执行的入口,它会调用 ThreadPoolExecutor.runWorker 方法:
- runWorker:ThreadPoolExecutor 的方法,用于执行任务
4.2、runWorker 方法
runWorker 是 Worker 执行任务的核心逻辑:
getTask():从任务队列中获取任务。
beforeExecute 和 afterExecute:任务执行前后的钩子方法,可以被子类重写。
processWorkerExit:处理线程退出逻辑。
4.3、getTask 方法
getTask 方法用于从任务队列中获取任务:
workQueue.poll:如果允许超时,则使用 poll 方法从队列中获取任务。
workQueue.take:如果不允许超时,则使用 take 方法从队列中获取任务。
5、工作原理
1、初始化:
创建 Worker 对象时,会初始化 firstTask 和 thread。
调用 thread.start() 启动线程,线程会执行 Worker 的 run 方法。
2、执行任务:
run 方法调用 runWorker,开始执行任务。
如果 firstTask 不为空,则执行 firstTask。
如果 firstTask 为空,则调用 getTask 从任务队列中获取任务。
3、任务循环:
runWorker 方法会不断从任务队列中获取任务并执行。
每次执行任务前会调用 beforeExecute,执行后会调用 afterExecute。
4、线程退出:
当 getTask 返回 null 时,表示线程需要退出。
调用 processWorkerExit 方法处理线程退出逻辑。
二、总结
Worker 是 ThreadPoolExecutor 的核心内部类,负责封装线程和任务,并实现任务的执行逻辑。它的主要特点包括:
1、封装线程和任务:通过 thread 和 firstTask 字段绑定线程和任务。
2、任务执行逻辑:通过 runWorker 方法从任务队列中获取任务并执行。
3、锁机制:继承自 AQS,用于防止任务被中断和控制线程的生命周期。
ThreadPoolExecutor的内部类Worker详细解析的更多相关文章
- 线程池 ThreadPoolExecutor 类的源码解析
线程池 ThreadPoolExecutor 类的源码解析: 1:数据结构的分析: private final BlockingQueue<Runnable> workQueue; // ...
- java类生命周期详细解析
(一)详解java类的生命周期 引言 最近有位细心的朋友在阅读笔者的文章时,对java类的生命周期问题有一些疑惑,笔者打开百度搜了一下相关的问题,看到网上的资料很少有把这个问题讲明白的,主要是因为目前 ...
- springmvc 项目完整示例06 日志–log4j 参数详细解析 log4j如何配置
Log4j由三个重要的组件构成: 日志信息的优先级 日志信息的输出目的地 日志信息的输出格式 日志信息的优先级从高到低有ERROR.WARN. INFO.DEBUG,分别用来指定这条日志信息的重要程度 ...
- include_path详细解析
include_path详细解析 原文地址:http://www.laruence.com/2010/05/04/1450.html 1.php默认的包含路径为 .;C:\php\pear 即 ...
- Intent的详细解析以及用法
Intent的详细解析以及用法 Android的四大组件分别为Activity .Service.BroadcastReceiver(广播接收器).ContentProvider(内容提供者 ...
- C++多态的实现及原理详细解析
C++多态的实现及原理详细解析 作者: 字体:[增加 减小] 类型:转载 C++的多态性用一句话概括就是:在基类的函数前加上virtual关键字,在派生类中重写该函数,运行时将会根据对象的实际类型 ...
- 对MySQL DELETE语法的详细解析
以下的文章主要描述的是MySQL DELETE语法的详细解析,首先我们是从单表语法与多表语法的示例开始的,假如你对MySQL DELETE语法的相关内容十分感兴趣的话,你就可以浏览以下的文章对其有个更 ...
- 转:二十一、详细解析Java中抽象类和接口的区别
转:二十一.详细解析Java中抽象类和接口的区别 http://blog.csdn.net/liujun13579/article/details/7737670 在Java语言中, abstract ...
- 单表扫描,MySQL索引选择不正确 并 详细解析OPTIMIZER_TRACE格式
单表扫描,MySQL索引选择不正确 并 详细解析OPTIMIZER_TRACE格式 一 表结构如下: 万行 CREATE TABLE t_audit_operate_log ( Fid b ...
- 在PHP中使用CURL,“撩”服务器只需几行——php curl详细解析和常见大坑
在PHP中使用CURL,"撩"服务器只需几行--php curl详细解析和常见大坑 七夕啦,作为开发,妹子没得撩就"撩"下服务器吧,妹子有得撩的同学那就左拥妹子 ...
随机推荐
- Paillier算法
介绍 1999年欧密会上,首次提出Paillier算法,2001年,Damgard等人对该方案简化,推出当前最优的Paillier方案. 加密方案 Carmichael函数 困难问题 合数剩余类问题( ...
- MySQL插入修改和删除
原文链接:https://blog.liuzijian.com/post/36d9bcaa-2ba7-26ca-6f97-b8ef7a058e95.html 插入 支持一次性插入多行,支持子查询 IN ...
- Shiftdel walkthrough Intermediate
点击查看代码 nmap -p- -A 192.168.167.174 Starting Nmap 7.94SVN ( https://nmap.org ) at 2024-11-12 00:09 UT ...
- P1787 [入门赛 #22]非众数 Hard Version 题解
P1787 [入门赛 #22]非众数 Hard Version 题解 原题传送门 这里对 pjh0625 的题解进行了详细解释 1. 读题 题目要求计算给定字符串中非众数子串的数量. 非众数子串 的定 ...
- 天翼云CDR基本概念
本文分享自天翼云开发者社区<天翼云CDR基本概念>,作者:f****n 产品定义 云容灾CT-CDR(Cloud Disaster Recovery)为云主机提供跨可用区的容灾保护能力,R ...
- have my hair cut
标题致敬传奇抗压王裤子. 今天去剪了头发.体验很好,老师帅. 但是还是一直很不安 我们 i 人剪了头发是这样的 剪头发不是换发型 但大概率得换 而且很快会剪短 乌龟的壳换了形状 或是变薄 肯定不安 一 ...
- Flink同步kafka到iceberg数据延迟,两个checkpoint后才可查询
一.问题描述 用户配置了高级参数很多,观察kafka增量数据不多,flink负载不高情况下两个checkpoint后才可查询到数据. 排查时hdfs有数据文件产生,但是mainfast文件中最新快 ...
- spark-sql查询Iceberg时处理流程
1.查询表结构 show create table data_lake_ods.test CREATE TABLE spark_catalog.data_lake_ods.test ( `user_n ...
- 赶上AI的大潮:在VSCode中使用DeepSeek编程的极简方法
1 赶上AI的大潮:在VSCode中使用DeepSeek编程的极简方法 1.1 背景 DeepSeek在春节期间突然大行其道,欣喜国力大增的同时,对于普通IT工作者,如何才能享受这一波AI红利,让 ...
- [WC2018] 通道 题解
三棵树就很毒瘤了,我们一棵一棵看. 关于第一棵树的路径,经典解法就是点分治和边分治,考虑哪种更加简单. 设 \(dis1/2/3(x)\) 表示 \(x\) 在第 \(1/2/3\) 棵树中的深度(第 ...