线程池的实现原理
3个主要步骤
步骤一:线程池会判断核心线程池是否都在执行任务。
如果都在执行任务,则需要进入第二步骤,尝试将任务加入到工作队列中,等待核心线程调用。
如果核心线程不都在执行任务,也即, 存在空闲(预热之后)或者当前工作线程数少于核心线程数,那么将创建一个新的工作线程执行任务。
步骤二: 线程池判断工作队列是否已满
如果没满,则将任务添加到队列中,等待核心线程调用。
如果已经满了,则进入第三个步骤,将尝试新建一个非核心线程处理执行任务。
步骤三:判断当前的工作线程数(核心线程与非核心线程之和)是否超过 maximumPoolSize(线程池所允许的最大线程数)。
如果没有超过,则创建一个新的非核心线程执行任务。
如果超过,则将触发饱和处理机制。
- 预热:当前运行的线程数大于等于corePoolSize。我们将这时的状态叫做预热完成。
- 非核心线程与核心线程的区别: 非核心线程受到线程池的keepLiveTime参数的影响,核心线程不受该参数的影响
线程池内部采用的队列类型,如有界与否, 阻塞与否都将对线程池的内部操作产生影响,有时间再写写这些内容。