一、定义

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详细解析的更多相关文章

  1. 线程池 ThreadPoolExecutor 类的源码解析

    线程池 ThreadPoolExecutor 类的源码解析: 1:数据结构的分析: private final BlockingQueue<Runnable> workQueue;  // ...

  2. java类生命周期详细解析

    (一)详解java类的生命周期 引言 最近有位细心的朋友在阅读笔者的文章时,对java类的生命周期问题有一些疑惑,笔者打开百度搜了一下相关的问题,看到网上的资料很少有把这个问题讲明白的,主要是因为目前 ...

  3. springmvc 项目完整示例06 日志–log4j 参数详细解析 log4j如何配置

    Log4j由三个重要的组件构成: 日志信息的优先级 日志信息的输出目的地 日志信息的输出格式 日志信息的优先级从高到低有ERROR.WARN. INFO.DEBUG,分别用来指定这条日志信息的重要程度 ...

  4. include_path详细解析

    include_path详细解析     原文地址:http://www.laruence.com/2010/05/04/1450.html 1.php默认的包含路径为 .;C:\php\pear 即 ...

  5. Intent的详细解析以及用法

    Intent的详细解析以及用法      Android的四大组件分别为Activity .Service.BroadcastReceiver(广播接收器).ContentProvider(内容提供者 ...

  6. C++多态的实现及原理详细解析

    C++多态的实现及原理详细解析 作者: 字体:[增加 减小] 类型:转载   C++的多态性用一句话概括就是:在基类的函数前加上virtual关键字,在派生类中重写该函数,运行时将会根据对象的实际类型 ...

  7. 对MySQL DELETE语法的详细解析

    以下的文章主要描述的是MySQL DELETE语法的详细解析,首先我们是从单表语法与多表语法的示例开始的,假如你对MySQL DELETE语法的相关内容十分感兴趣的话,你就可以浏览以下的文章对其有个更 ...

  8. 转:二十一、详细解析Java中抽象类和接口的区别

    转:二十一.详细解析Java中抽象类和接口的区别 http://blog.csdn.net/liujun13579/article/details/7737670 在Java语言中, abstract ...

  9. 单表扫描,MySQL索引选择不正确 并 详细解析OPTIMIZER_TRACE格式

    单表扫描,MySQL索引选择不正确 并 详细解析OPTIMIZER_TRACE格式     一 表结构如下:  万行 CREATE TABLE t_audit_operate_log (  Fid b ...

  10. 在PHP中使用CURL,“撩”服务器只需几行——php curl详细解析和常见大坑

    在PHP中使用CURL,"撩"服务器只需几行--php curl详细解析和常见大坑 七夕啦,作为开发,妹子没得撩就"撩"下服务器吧,妹子有得撩的同学那就左拥妹子 ...

随机推荐

  1. Paillier算法

    介绍 1999年欧密会上,首次提出Paillier算法,2001年,Damgard等人对该方案简化,推出当前最优的Paillier方案. 加密方案 Carmichael函数 困难问题 合数剩余类问题( ...

  2. MySQL插入修改和删除

    原文链接:https://blog.liuzijian.com/post/36d9bcaa-2ba7-26ca-6f97-b8ef7a058e95.html 插入 支持一次性插入多行,支持子查询 IN ...

  3. Shiftdel walkthrough Intermediate

    点击查看代码 nmap -p- -A 192.168.167.174 Starting Nmap 7.94SVN ( https://nmap.org ) at 2024-11-12 00:09 UT ...

  4. P1787 [入门赛 #22]非众数 Hard Version 题解

    P1787 [入门赛 #22]非众数 Hard Version 题解 原题传送门 这里对 pjh0625 的题解进行了详细解释 1. 读题 题目要求计算给定字符串中非众数子串的数量. 非众数子串 的定 ...

  5. 天翼云CDR基本概念

    本文分享自天翼云开发者社区<天翼云CDR基本概念>,作者:f****n 产品定义 云容灾CT-CDR(Cloud Disaster Recovery)为云主机提供跨可用区的容灾保护能力,R ...

  6. have my hair cut

    标题致敬传奇抗压王裤子. 今天去剪了头发.体验很好,老师帅. 但是还是一直很不安 我们 i 人剪了头发是这样的 剪头发不是换发型 但大概率得换 而且很快会剪短 乌龟的壳换了形状 或是变薄 肯定不安 一 ...

  7. Flink同步kafka到iceberg数据延迟,两个checkpoint后才可查询

    一.问题描述 用户配置了高级参数很多,观察kafka增量数据不多,flink负载不高情况下两个checkpoint后才可查询到数据.   排查时hdfs有数据文件产生,但是mainfast文件中最新快 ...

  8. spark-sql查询Iceberg时处理流程

    1.查询表结构 show create table data_lake_ods.test CREATE TABLE spark_catalog.data_lake_ods.test ( `user_n ...

  9. 赶上AI的大潮:在VSCode中使用DeepSeek编程的极简方法

    1 赶上AI的大潮:在VSCode中使用DeepSeek编程的极简方法 1.1 背景   DeepSeek在春节期间突然大行其道,欣喜国力大增的同时,对于普通IT工作者,如何才能享受这一波AI红利,让 ...

  10. [WC2018] 通道 题解

    三棵树就很毒瘤了,我们一棵一棵看. 关于第一棵树的路径,经典解法就是点分治和边分治,考虑哪种更加简单. 设 \(dis1/2/3(x)\) 表示 \(x\) 在第 \(1/2/3\) 棵树中的深度(第 ...