线程池中的线程分为核心线程、非核心线程。前者是常驻在线程池中的工作线程,初始化有两种方式,一种是向线程池添加任务时,被动初始化;二是主动调研prestartAllCoreThreads方法。
当线程池中blocking队列满了的情况下,为了增加线程池的任务处理能力,线程池会增加非核心线程。两者的数量是在构造线程池对象的时候进行设置的,也可以动态进行更改。
由于非核心线程是为了解决在任务过多的情况下临时增加的,所以当任务完成,工作线程处于空闲状态时,就需要进行回收线程。又因为所有工作线程都是在阻塞队列获取要执行的任务,只要在一定时间内阻塞队列没有任何可以处理的任务,这个线程就可以被回收了。这个回收机制是通过阻塞队列中的Poll方法来完成的,这个方法中提供了超时时间和超时时间单位两个参数(keepalived),当前线程没有从阻塞队列中获取到任务的时候,从而Poll方法会返回Null,从而会终止当前线程,完成线程的回收。
默认情况下,线程池只能回收非核心线程,如果想对核心线程也可以被回收,需要设置allowCoreThreadTimeOut属性为true就可以了。一般情况下,不会回收核心线程,因为线程池本身就是实现线程的复用,而且,这些核心线程在没有处理任务时,处于阻塞状态,并没有占用CPU资源。