引言
除了实现接口和继承父类的方法来实现线程,我们还可以通过线程池来实现线程。那么线程池是怎么执行的呢?
线程池就像一个大工厂,管理线程的创建和关闭。具体执行流程如下:
线程的执行流程
提交线程任务
当提交一个新的线程任务时,线程池首先会判断是否存在空闲线程,存在空闲线程的话会分配线程任务给空闲线程。
检查核心线程数
若没有空闲线程的话线程池会再次进行判断:当前线程数是否超过了核心线程数,假如没有超过核心线程数,线程池会创建新的线程来执行当前提交的线程任务。
检查工作队列
若已经超过核心线程数,线程池会将超出的线程暂时放在工作队列,一般是一个阻塞队列,该队列遵循先进先出的FIFO思想,当有空闲线程时,线程池会取出工作队列中最先进入队列的线程任务交给空闲线程。
检查最大线程数
当工作队列也装满了之后,线程池就会检查最大线程数,假如已存在线程数未超过最大线程数,线程池会再次创建新的线程来执行线程任务。
执行拒绝策略
当最大线程数也满了之后,再次接受新的线程任务时,线程池就会执行拒绝策略处理新的任务。通常拒绝策略分为四种:
AbortPolicy:丢弃任务,并且抛出RejectExecutionExpection异常;
DiscardPolicy:只丢弃任务,不抛出异常
DiscardOldestPlolicy:将队列中早的任务取出,然后将新任务放入队列。
CallerRunsPolicy:由原来的调用线程执行(谁调用,谁执行)。