线程池相关知识点复习

1、线程池的创建

1、如果当前运行的线程少于corePoolSize,则创建新的线程来执行任务(注意:执行这一个步骤需要获取全局锁)

2、如果运行的线程等于或多于corePoolSize,则将任务加入BlockingQueue。

3、如果无法将任务加入BlockingQueue(队列已满),则创建新的线程来执行任务(注意:执行这一个步骤需要获取全局锁)

4、如果创建新的线程将使当前运行的线程超出maximunPoolSize,任务将会被拒绝,并且调用RejectedExecutionHandler.rejectExecution()方法。

2、线程池的关闭

可以通过线程池的shutdownshutdownNow方法来关闭线程池。他们的原理是遍历线程池中的工作线程,然后逐个调用线程的interrupt方法来中断线程,所以无法响应中断的任务可能永远无法终止。

但是二者也存在一定的区别:

  • shutdownNow首先将线程池的状态设为STOP,然后尝试停止所有的正在执行或者暂停任务的线程,并返回等待执行的任务的列表。
  • shutdown只是将线程池的状态设置成SHUTDOWN状态,然后中断没有正在执行任务的线程。

主要调用了这二者中的任意一个,isShutdown方法就会返回True。当所有的任务都已经关闭之后,才表示线程池关闭成功,这时调用isTerminated方法就会反悔True。

至于要使用哪一个方法,应该由提交到线程池的任务特性来决定,通常采用shutdown方法来关闭线程池,如果任务不一定要执行完,则可以使用shutdownNow方法。

3、线程池的几个关键参数

  • corePoolSize:线程池的基本大小
  • runnableTaskQueue:任务队列
    • ArrayBlockQueue:一个基于数组结构的有界阻塞队列,此队列按照FIFO原则对数据进行排序
    • LinkedBlockingQueue:一个基于链表结构的阻塞队列
    • SynchronizedQueue:一个不存储元素的阻塞队列
    • PriorityBlockingQueue:一个具有优先级的无限阻塞队列
  • maximumPoolSize:线程池的最大数量,即线程池允许创建的最大线程数
  • ThreadFactory用于设置创建线程的工厂,可以通过线程工厂来给每个创建出来的线程设置更有意义的名字。
posted @ 2022-08-01 21:24  yfwei  阅读(19)  评论(0编辑  收藏  举报