ThreadPoolTaskExecutor和ThreadPoolExecutor的区别
时间: 2023-10-19 07:32:21 浏览: 134
redis lits queue 和 ThreadPoolExecutor 结合
ThreadPoolTaskExecutor是Spring框架提供的ExecutorService的实现类,用于创建和管理线程池。它可以通过配置一系列参数来调整线程池的行为。
常用的ThreadPoolTaskExecutor参数包括:
1. corePoolSize:核心线程数,指定线程池中保留的线程数,即使这些线程处于空闲状态。默认值为1。
2. maxPoolSize:最大线程数,指定线程池中允许的最大线程数量。当任务数量超过corePoolSize时,线程池会创建新的线程,直到达到maxPoolSize。默认值为Integer.MAX_VALUE。
3. queueCapacity:任务队列容量,指定用于保存等待执行任务的队列的容量。当任务数量超过corePoolSize时,新的任务会被放入该队列等待执行。默认值为Integer.MAX_VALUE。
4. keepAliveSeconds:非核心线程的存活时间,指定当线程池中的线程数量超过corePoolSize时,多余的空闲线程的存活时间。默认值为60秒。
5. threadNamePrefix:线程名前缀,指定创建的线程的名称前缀。默认值为"taskExecutor-"。
6. rejectionPolicy:拒绝策略,指定当任务无法被接受时的处理方式。常用的策略包括:
- CallerRunsPolicy:由调用者所在的线程执行该任务。
- AbortPolicy:抛出RejectedExecutionException异常。
- DiscardPolicy:直接丢弃任务。
- DiscardOldestPolicy:丢弃队列中最旧
阅读全文