多线程中线程池常见7个参数的详解以及执行流程

一 线程池常见参数

1.1 概念

1.2 7个参数说明

7个参数:

int corePoolSize, 常驻线程数量(核心) int maximumPoolSize,最大线程数量 long keepAliveTime,TimeUnit unit,线程存活时间 BlockingQueue<Runnable> workQueue,阻塞队列(排队的线程放入) ThreadFactory threadFactory,线程工厂,用于创建线程 RejectedExecutionHandler handler拒绝策略(线程满了)

1.3 coresize和maxsize,poolsize

1.corePoolSize:

线程池的核心线程数量,线程池的基本大小,即在没有任务需要执行的时候线程池的大小,并且只有在工作队列满了的情况下才会创建超出这个数量的线程。

2.maximumPoolSize:

线程池中允许的最大线程数

3.poolSize:

线程池中当前线程的数量

3者之间的关系:

新提交一个任务时的处理流程很明显:

1、如果当前线程池的线程数还没有达到基本大小(poolSize < corePoolSize),无论是否有空闲的线程新增一个线程处理新提交的任务;

2、如果当前线程池的线程数大于或等于基本大小(poolSize >= corePoolSize) 且任务队列未满时,就将新提交的任务提交到阻塞队列排队,等候处理workQueue.offer(command);

3、如果当前线程池的线程数大于或等于基本大小(poolSize >= corePoolSize) 且任务队列满时;

3.1、当前poolSize<maximumPoolSize,那么就新增线程来处理任务;

3.2、当前poolSize=maximumPoolSize,那么意味着线程池的处理能力已经达到了极限,此时需要拒绝新增加的任务。至于如何拒绝处理新增的任务,取决于线程池的饱和策略RejectedExecutionHandler。

1.4 newFixedThreadPool

newFixedThreadPool中设定的线程数是核心线程数,还是最大线程数,开源代码如下:

底层继续查看 new ThreadPoolExecutor的源代码

通过查看源码:答案是:核心线程数和最大线程数都设置成了定义的线程数量。

经验分享 程序员 微信小程序 职场和发展