一文理解ThreadPoolExecutor线程池以及运行时间

线程池(Thread Pool)是一种管理多个线程的机制,它通过重用一组已创建的线程来执行多个任务,从而减少线程创建和销毁的开销,提高系统性能和资源利用率。在 Java 中,线程池由 java.util.concurrent 包中的 ThreadPoolExecutor 类提供。
线程池(Thread Pool)是一种管理多个线程的机制,它通过重用一组已创建的线程来执行多个任务,从而减少线程创建和销毁的开销,提高系统性能和资源利用率。在 Java 中,线程池由 java.util.concurrent 包中的 ThreadPoolExecutor 类提供。下面详细介绍线程池的原理、组成部分和工作机制。

1. 线程池简介

1.1 线程池核心组成部分

  1. 核心线程数(corePoolSize)

    • 线程池中保持的核心线程数量。即使这些线程处于空闲状态,它们也不会被销毁,除非设置了 allowCoreThreadTimeOut
  2. 最大线程数(maximumPoolSize)

    • 线程池中允许的最大线程数量。当工作队列已满且请求数超过核心线程数时,线程池会创建新线程,直到总线程数达到最大线程数。
  3. 工作队列(workQueue)

    • 用于保存等待执行的任务的队列。常用的队列类型有 LinkedBlockingQueueArrayBlockingQueueSynchronousQueue 等。
  4. 线程工厂(ThreadFactory)

    • 用于创建新线程的工厂,可以定制线程的创建过程,例如设置线程名称、优先级等。
  5. 拒绝策略(RejectedExecutionHandler)

    • 当任务无法被线程池接受时,执行的处理策略。常见的策略有 AbortPolicy(默认)、CallerRunsPolicyDiscardPolicyDiscardOldestPolicy

1.2 线程池的工作机制

  1. 提交任务

    • 当客户端向线程池提交任务时,线程池会根据当前的线程数和工作队列的状态决定如何处理该任务。
  2. 处理任务的步骤

    • 核心线程数未达到 corePoolSize:通过线程处理任务。
    • 核心线程数已达到 corePoolSize:将任务加入工作队列。
    • 工作队列已满:若线程数未达到 maximumPoolSize,创建新线程处理任务。
    • 线程数已达到 maximumPoolSize:执行拒绝策略。
  3. 线程的重用

    • 当线程完成任务后,它不会被销毁,而是返回线程池成为空闲线程,等待处理新的任务。

1.3 线程池的状态转换

线程池的状态可以通过 ThreadPoolExecutor 的内部状态字段进行控制,主要包括以下几种状态:

  1. RUNNING:可以接收新任务并处理队列中的任务。
  2. SHUTDOWN:不接收新任务,但会处理队列中的任务。
  3. STOP:不接收新任务,也不处理队列中的任务,并中断正在执行的任务。
  4. TIDYING:所有任务都已终止,workQueue 为空,正在执行 terminated() 钩子方法。
  5. TERMINATEDterminated() 钩子方法执行完成。

2. 线程池的任务场景

线程池有几个关键参数:核心线程数、最大线程数、回收时间、工作队列等。
接下来将使用一个自定义线程池Demo的方式来讲解线程池的工作的流程,代码如下:

package hero.mps.basic;

import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;

public class ThreadPollExecutorTest {
    // 核心线程池大小
    private static int corePoolSize = 10;
    // 最大线程池大小
    private static int maxPollSize = 20;
    // 线程空闲时间(秒)
    private static int keepAliveTime = 5;
    // 阻塞队列大小
    private static int blockQueueSize = 30;
    // 任务总数
    private static int taskNUm = 41;
    // 已执行的任务数量(使用AtomicInteger保证线程安全)
    private static AtomicInteger taskNumExecuted;


    /**
     * 任务数≤核心线程,线程池工作的线程=任务数
     * 核心线程数+队列容量<任务数≤最大线程数+队列容量,线程池工作的线程=任务数-队列容量
     * @param args
     */

    public static void main(String[] args) {
        // 初始化已执行的任务数量为0
        taskNumExecuted = new AtomicInteger(0);

        // 创建一个Thr
  • 29
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
ThreadPoolExecutorJava的一个线程池实现类。它继承自ExecutorService接口,可以用来管理和执行线程任务。ThreadPoolExecutor线程池提供了更灵活的线程管理和任务调度的功能,并且可以根据需要进行配置。可以通过指定核心线程数、最大线程数、线程存活时间和任务队列等参数来创建和配置ThreadPoolExecutor线程池。 使用ThreadPoolExecutor线程池可以提供以下几个优点: 1. 降低线程创建和销毁的开销。线程池可以重用已经创建的线程,减少了频繁创建和销毁线程的开销。 2. 提高系统的响应速度。线程池可以并发执行多个任务,提高了系统的处理能力和响应速度。 3. 控制线程并发数量。通过设置线程池的核心线程数和最大线程数,可以控制系统的并发线程数量,避免资源耗尽和系统崩溃的风险。 4. 提供任务调度和管理。线程池可以将任务按照一定的策略和优先级进行调度和执行,方便管理任务的执行顺序和优先级。 总之,ThreadPoolExecutor线程池是一个灵活可配置的线程管理和任务调度工具,可以提高系统的并发处理能力和响应速度。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [线程池ThreadPoolExecutor详解(整理详细)](https://blog.csdn.net/trusause/article/details/125747447)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [ThreadPoolExecutor线程池的使用方法](https://download.csdn.net/download/weixin_38659648/12746355)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

heromps

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值