https://blog.csdn.net/weixin_40757930/article/details/124727955

线程池的执行流程:

Untitled

为什么核心线程池满了后 不直接创建新的线程去执行新任务?

而是先交给任务队列呢?

并发编程的艺术》中的解答是:

TreadPoolExecutor 采取上述步骤的总体设计思路,是为了在执行 execute() 方法时,尽可能地避免获取全局锁(那将会是一个严重的可伸缩瓶颈)。在 ThreadPoolExecutor 完成预热之后(当前运行的线程数大于等于 corePoolSize),几乎所有 execute() 方法调用都是执行步骤 2 也就是放入队列,而步骤 2 不需要获取全局锁。

Untitled

因为如果核心线程满了就创建新的线程去执行,达到最大线程数之后再放入队列,那么新创建线程就需要获取全局锁,对性能有很大的损耗。

而且如果正在被核心线程执行的任务很快的执行完,就可以直接从任务队列中取出新的任务执行。

这样不需要创建新的线程也可以完成任务,那么这样还可以节省一部分内存。