线程池相关知识点复习
1、线程池的创建
1、如果当前运行的线程少于corePoolSize,则创建新的线程来执行任务(注意:执行这一个步骤需要获取全局锁)
2、如果运行的线程等于或多于corePoolSize,则将任务加入BlockingQueue。
3、如果无法将任务加入BlockingQueue(队列已满),则创建新的线程来执行任务(注意:执行这一个步骤需要获取全局锁)
4、如果创建新的线程将使当前运行的线程超出maximunPoolSize,任务将会被拒绝,并且调用RejectedExecutionHandler.rejectExecution()方法。
2、线程池的关闭
可以通过线程池的shutdown
和shutdownNow
方法来关闭线程池。他们的原理是遍历线程池中的工作线程,然后逐个调用线程的interrupt方法来中断线程,所以无法响应中断的任务可能永远无法终止。
但是二者也存在一定的区别:
- shutdownNow首先将线程池的状态设为STOP,然后尝试停止所有的正在执行或者暂停任务的线程,并返回等待执行的任务的列表。
- shutdown只是将线程池的状态设置成SHUTDOWN状态,然后中断没有正在执行任务的线程。
主要调用了这二者中的任意一个,isShutdown方法就会返回True。当所有的任务都已经关闭之后,才表示线程池关闭成功,这时调用isTerminated方法就会反悔True。
至于要使用哪一个方法,应该由提交到线程池的任务特性来决定,通常采用shutdown方法来关闭线程池,如果任务不一定要执行完,则可以使用shutdownNow方法。
3、线程池的几个关键参数
- corePoolSize:线程池的基本大小
- runnableTaskQueue:任务队列
- ArrayBlockQueue:一个基于数组结构的有界阻塞队列,此队列按照FIFO原则对数据进行排序
- LinkedBlockingQueue:一个基于链表结构的阻塞队列
- SynchronizedQueue:一个不存储元素的阻塞队列
- PriorityBlockingQueue:一个具有优先级的无限阻塞队列
- maximumPoolSize:线程池的最大数量,即线程池允许创建的最大线程数
- ThreadFactory用于设置创建线程的工厂,可以通过线程工厂来给每个创建出来的线程设置更有意义的名字。