线程池-ThreadPoolExecutor

本文详细介绍了线程池的工作原理,包括核心类ThreadPoolExecutor的参数设置与功能,如线程数量控制、任务队列管理及拒绝策略。同时,探讨了线程池在不同场景下的应用与创建方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

线程池:
线程执行任务后,不被销毁,再次执行其他任务。
核心类:ThreadPoolExecutor
corePoolSize:大小
maximumPoolSize:最大线程数
keepAliveTime:没执行任务存活时间
unit:时间单位
workQueue:阻塞队列
threadFactory:线程工厂
handler:当拒绝处理任务时的策略(
ThreadPoolExecutor.AbortPolicy:丢弃任务并抛出RejectedExecutionException异常。
ThreadPoolExecutor.DiscardPolicy:也是丢弃任务,但是不抛出异常。
ThreadPoolExecutor.DiscardOldestPolicy:丢弃队列最前面的任务,然后重新尝试执行任务(重复此过程)
ThreadPoolExecutor.CallerRunsPolicy:由调用线程处理该任务

ThreadPoolExecutor(int corePoolSize, 	//初始化创建线程数量
                              int maximumPoolSize,  //线程可创建最大数量,任务数量超过corePoolSize值,先将任务放到队列中,队列满了或者异常,创建线程<maximumPoolSize,超过maximumPoolSize,handler处理
                              long keepAliveTime,  //线程存在时间,超出corePoolSize线程数会激活
                              TimeUnit unit,  //时间单位
                              BlockingQueue<Runnable> workQueue,  //存入的任务队列(LinkedBlockQueue、Synchronous)
                              ThreadFactory threadFactory,  //产生线程的工厂
                              RejectedExecutionHandler handler)  //拒绝处理任务时对应策略

该类(ThreadPoolExecutor)继承抽象类:AbstractPoolExecutor,实现接口:ExecutorService 继承接口 Executor
涉及核心方法:
execute:提交任务到线程池
submit:提交任务到线程池,并返回执行结果Future。
shutdown:关闭线程池,若有任务,等待缓存队列执行完后关闭
shutdownNow:立即关闭,尝试关闭正在执行的任务

声明线程池:由ThreadPoolExecutor实现
Executors.newCachedThreadPool(); //创建一个缓冲池,缓冲池容量大小为Integer.MAX_VALUE
Executors.newSingleThreadExecutor(); //创建容量为1的缓冲池
Executors.newFixedThreadPool(int); //创建固定容量大小的缓冲池

### Java 中 Executors 和 ThreadPoolExecutor 的区别 #### Executor 接口层次结构 `Executors` 并不是一个具体的线程池实现,而是提供了若干静态工厂方法来创建不同类型的线程池。这些线程池最终都是基于 `ThreadPoolExecutor` 实现的[^2]。 #### 创建方式的不同 - **Executors 工具类** 使用 `Executors` 类可以通过调用其提供的静态方法快速获得预定义配置好的几种常见类型线程池实例,比如固定大小、缓存型以及单一线程等特殊用途的线程池- **ThreadPoolExecutor 手动构建** 而如果想要更精细地控制线程池的行为,则可以直接使用 `ThreadPoolExecutor` 构造器来自定义核心线程数量、最大线程数量、保持活动时间、工作队列以及其他属性[^3]。 ```java // 使用 Executors 创建新固定的线程池 ExecutorService fixedPool = Executors.newFixedThreadPool(10); // 自定义 ThreadPoolExecutor 参数 ThreadPoolExecutor customPool = new ThreadPoolExecutor( 5, // 核心线程数 10,// 最大线程数 60L, TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>() ); ``` #### 配置灵活性对比 由于 `Executors` 返回的对象通常具有较为简单的内部逻辑设定,在某些复杂应用场景下可能无法完全满足需求;相反,直接操作 `ThreadPoolExecutor` 则能够给予开发者更大的自由度去调整各项参数以适应具体业务场景的要求[^4]。 #### 功能特性上的差异 除了基本的任务提交功能外,`ThreadPoolExecutor` 还支持更多高级特性的定制化选项,例如设置不同的拒绝策略处理超出容量范围之外的新任务请求,或是指定特定的工作队列类型影响任务排队机制等等[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值