JAVA线程池线程复用机制核心摘要

1、线程创建时机

1.1、submitTask

executor.submit(task);

java 复制代码
ExecutorService executor = Executors.newFixedThreadPool(3);

// 创建一个 Callable 任务
 Callable<Integer> task = new Callable<Integer>() {
    @Override
    public Integer call() throws Exception {
       System.out.println("Task is being processed by " + Thread.currentThread().getName());
       Thread.sleep(1000); // 模拟一些工作
       return 42; // 返回结果
            }
};

Future<Integer> future = executor.submit(task);

1.2、addWorker

java 复制代码
        int c = ctl.get();
        if (workerCountOf(c) < corePoolSize) {
            if (addWorker(command, true))
                return;
            c = ctl.get();
        }

1.3、创建线程&跟worker绑定

java 复制代码
        Worker(Runnable firstTask) {
            setState(-1); // inhibit interrupts until runWorker
            this.firstTask = firstTask;
            this.thread = getThreadFactory().newThread(this);
        }

this.thread = getThreadFactory().newThread(this);

这里是worker跟线程关联的核心,new Thread 的时候把woker作为runable传进去了,后面thread.start()的时候,会回调worker的run()方法,这样线程就跟worker绑定了。

java 复制代码
 if (workerAdded) {
                    t.start();
                    workerStarted = true;
                }

启动线程,回调worker 的 runWorker方法

1.4、线程复用核心

java 复制代码
final void runWorker(Worker w) {
        Thread wt = Thread.currentThread();
        Runnable task = w.firstTask;
        w.firstTask = null;
        w.unlock(); // allow interrupts
        boolean completedAbruptly = true;
        try {
            while (task != null || (task = getTask()) != null) {
                w.lock();

while循环,有任务执行,无任务则block,等待任务,这样线程就能做复用了。

相关推荐
xuhaoyu_cpp_java6 分钟前
MyBatis学习(二)
java·经验分享·笔记·学习·mybatis
石榴树下的七彩鱼11 分钟前
智能抠图 API 多语言接入实战:从零到上线的 Python / Java / PHP / JS 完整教程(附避坑指南)
java·python·php·智能抠图·api接入·石榴智能·shiliuai
天渺工作室14 分钟前
别再写改名脚本了,一个 Vite 插件搞定压缩、校验、自动哈希命名vite-plugin-pack-orchestrator
前端·vite
无限进步_20 分钟前
C++ 继承机制完全解析:从基础原理到菱形继承问题
java·开发语言·数据结构·c++·vscode·后端·算法
roman_日积跬步-终至千里21 分钟前
【系统架构师案例题-知识点】数据库与缓存设计
数据库·缓存·系统架构
大龄程序员狗哥23 分钟前
第30篇:使用Flask部署你的第一个AI模型——打造简易Web API(项目实战)
前端·人工智能·flask
SamDeepThinking33 分钟前
适合中小型企业的出口入口网关微服务
java·后端·架构
不知名的忻33 分钟前
并查集(QuickUnion)
java·数据结构·算法·并查集
不剪发的Tony老师37 分钟前
DBcooper:一款面向开发者的现代数据库客户端
数据库·sql
likerhood41 分钟前
Java实现选择题选项乱序算法
java·开发语言·算法