ThreadPoolExecutor的内部类Worker详细解析

news/2025/2/23 1:09:28/文章来源:https://www.cnblogs.com/jock766/p/18731732

一、定义

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,用于防止任务被中断和控制线程的生命周期。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/888245.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

webdriver打开Chrome闪退问题的解决方法

现状:webdriver控制打开Chrome后闪退解决方案:强制等待,使用time.sleep()

noip 2025.2.22

T3 题目大意: 给你一棵树和一个排列 \(p\),定义 \(l \sim r\) 的 \(val\) 值为 \(dep_{LCA(p_{l \sim r})}\),求 \[\sum_{i = 1}^n \sum_{j=i}^n val_{l, r} \]\(n \le 6 \times 10^5\) 赛时思路: 先将 p 给直接映射上去。 考虑 \(\text{dsu on tree}\),用 set 维护每个子…

Java基础day3

Scanner对象 方法的重载 方法的调用 命令行传参 可变参数 数组 类与对象 封装,继承-extendsJava基础day3 Scanner对象Scanner scanner=new Scanner(System.in);if(scanner.hasNext()){//用next接收String str=scanner.nextLine();System.out.println("输出内容…

2025-02-22-steampy-on-steam

Why 官方 插件僅做了 Chrome 版本,並且尚未上架,想給 FF 也做一個。因爲功能比較簡單,所以試圖用 Tampermonkey 做了一個版本出來,想着自己湊合中,因爲本人不需要代購價格,所以僅僅顯示 CDKey 的價格。總體樣式和官方的差距比較多,這個只是一個 Demo 腳本,後續有空了會…

[题解]AtCoder Beginner Contest 394(ABC394)

A - 22222 遍历字符串\(s\),按题意输出所有2即可。点击查看代码 #include<bits/stdc++.h> #define int long long using namespace std; string s; signed main(){cin>>s;for(auto a:s) if(a==2) cout<<a;return 0; }B - cat 按题意模拟即可。点击查看代码 …

GitOps项目上篇之Argo CD环境准备

作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任。 目录一.GitOps概述1.什么是GitOps2.基于Argo实现GitOps方案架构二.GitOps项目环境准备实战案例1.主机角色规划2.部署gitlab相关环境3.部署k8s相关环境4.部署ArgoCD默认启用tls环境基于NodePort暴露4.1 Argo概…

[tldr] 配置windows terminal使用git bash

windows terminal默认使用power shell作为shell,但是power shell不好用,还是习惯linux的命令行行为. 参考Windows Terminal 配置 Git Bash 添加新的配置文件在windows terminal中点击设置选项点击添加配置文件按钮编辑配置内容 一个配置文件主要来自之前的配置文件的内容主要分…

【原创工具】文件清单生成器 By怜渠客

【原创工具】文件清单生成器 By怜渠客 刚在论坛看到了一个文件列表生成器 https://www.52pojie.cn/thread-2008605-1-1.html ,和我去年写的一个软件很像,当时我也是有需求,要把一个文件夹里及其子文件夹里所有的文件列出来,就临时弄了个小软件,现在我重新修复完善了一下,…

windows使用命令行管理进程

前言 在windows中,我们通常使用GUI图形画面的任务管理器来管理进程。 任务管理器提供了一个较为友好的图形界面,然而他也存在一定问题。 首先,任务管理器就要吃掉一部分性能。 而且,当你在任务管理器页面,点击按名称排序时,那可能会出现灾难性的卡顿,这对一台旧电脑来说…

postman的几种参数化

1.环境变量方式设置:创建环境:点击 Postman 右上角的 Environments > Create New。输入环境名称(如 Dev、test),并添加键值对(如 base_url: https://api.vvhan.com)。使用变量:在请求 URL 或请求体中用双花括号引用变量:{{base_url}}/users。切换环境时,变量会自动…

第十五届蓝桥杯省赛

第十五届蓝桥杯省赛 1.握手问题#include <iostream> using namespace std; int main() { //划分为43,7两组 //(43*42)/2+7*43=28*43 cout<<28*43;return 0; }2.小球反弹(难)分析: 当做两个方向往返代码:/* 考点:速度分解 分解为x轴往返,y轴往返(回到左上角起…

OpenWRT安装Caddy实现WebDAV协议的NAS盘

Caddy带有WebDAV插件,可以安装在OpenWRT上,用于提供WebDAV协议的NAS服务。 Windows资源管理器,WinSCP,MAC的Finder,Android上的CX文件管理器都可以作为WebDAV的客户端。 WebDAV使用过程中可以直接打开文件,修改后保存,非常方便,感觉Samb没区别。但其使用https协议,安全…