天天看点

线程池的实现原理线程池的实现原理

线程池的实现原理

3个主要步骤

步骤一:线程池会判断核心线程池是否都在执行任务。

  • 如果都在执行任务,则需要进入第二步骤,尝试将任务加入到工作队列中,等待核心线程调用。
  • 如果核心线程不都在执行任务,也即, 存在空闲(预热之后)或者当前工作线程数少于核心线程数,那么将创建一个新的工作线程执行任务。

步骤二: 线程池判断工作队列是否已满

  • 如果没满,则将任务添加到队列中,等待核心线程调用。
  • 如果已经满了,则进入第三个步骤,将尝试新建一个非核心线程处理执行任务。

步骤三:判断当前的工作线程数(核心线程与非核心线程之和)是否超过 maximumPoolSize(线程池所允许的最大线程数)。

  • 如果没有超过,则创建一个新的非核心线程执行任务。
  • 如果超过,则将触发饱和处理机制。
  • 预热:当前运行的线程数大于等于corePoolSize。我们将这时的状态叫做预热完成。
  • 非核心线程与核心线程的区别: 非核心线程受到线程池的keepLiveTime参数的影响,核心线程不受该参数的影响

线程池内部采用的队列类型,如有界与否, 阻塞与否都将对线程池的内部操作产生影响,有时间再写写这些内容。