ThreadPoolExecutor 是怎么控制非核心线程超时的前言调试分析
前言java的线程池最根本的都是使用的ThreadPoolExecutor,其构造方法的参数、线程增长顺序、拒绝策略经常在面试中被问到。但是有一个不常见的问题:keepAliveTime是怎么生效的?非核心线程是怎么超时退出的呢?其实这个问题在我们真正看完ThreadPoolExecutor的源码和逻辑之后,其实是很容易说清楚的。先说结论:在线程池里的线程会一个死循环里阻塞式地从队列里获取任务来执行,而当线程数超过核心线程数的时候,这里的阻塞时间是keepAliveTime,超过这个时间没有获取