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,等待任务,这样线程就能做复用了。

相关推荐
魔道不误砍柴功2 分钟前
Java Function 高级使用技巧:从工程实战中来
java·开发语言·python
不知名。。。。。。。。3 分钟前
仿muduo库实现高并发服务器----EventLoop与线程整合起来
java·开发语言·jvm
张一凡934 分钟前
easy-model 在任务管理应用中的实际应用
前端·react.js
专业流量卡5 分钟前
React useMemo 源码ai解析
前端
编程大师哥5 分钟前
JAVA 集合框架进阶
java·开发语言
TechFind6 分钟前
AI Agent 开发完整教程:从零到上线的实战指南
java·javascript
xixihaha13246 分钟前
使用Flask快速搭建轻量级Web应用
jvm·数据库·python
春日见8 分钟前
车载系统中的CPU与内存监管
java·开发语言·驱动开发·docker·计算机外设
用户2565676133469 分钟前
Android Input 系统事件分发机制深度解析
java
fengxin_rou10 分钟前
黑马点评实战篇|第六篇:秒杀优化
java·开发语言·数据库·redis·分布式