引言
在Java高并发编程中,线程池是提升性能、避免资源耗尽的核心技术。但你是否遇到过这些问题?
-
线程池任务堆积导致内存溢出(OOM)!
-
线程池参数配置不当,系统吞吐量不升反降!
-
任务执行异常却无日志,问题排查如大海捞针!
本文将深入剖析ThreadPoolExecutor
的底层原理,结合代码示例,涵盖参数调优、拒绝策略、监控技巧等实战内容,带你彻底玩转Java线程池!
一、ThreadPoolExecutor核心原理
1.1 线程池的五大核心参数
参数名 | 作用描述 |
---|---|
corePoolSize |
核心线程数,即使空闲也不会被回收(除非设置allowCoreThreadTimeOut ) |
maximumPoolSize |
线程池最大线程数 |
keepAliveTime |
非核心线程空闲存活时间(单位由TimeUnit 指定) |
workQueue |
任务队列,用于存放待执行任务(常见实现类:LinkedBlockingQueue 、SynchronousQueue ) |
threadFactory |
线程工厂,用于创建线程(可自定义线程名称、优先级等) |
handler |
拒绝策略,当任务队列和线程池都满时的处理方式(默认抛出RejectedExecutionException ) |
1.2 线程池工作流程
-
提交任务时,优先创建核心线程。
-
核心线程满后,任务进入队列等待。
-
队列满后,创建非核心线程直到达到
maximumPoolSize
。 -
线程和队列都满时,触发拒绝策略。
二、线程池创建与基础使用
2.1 创建线程池(标准方式)
import java.util.concurrent.*;
public class ThreadPoolDemo {
public static void main(String[] args) {
//