线程池

首先,线程池本质上是一种池化技术,而池化技术是一种资源复用的思想,比较常见的 有连接池、内存池、对象池。

而线程池里面复用的是线程资源,它的核心设计目标,我认为有两个:

  1. 减少线程的频繁创建和销毁带来的性能开销,因为线程创建会涉及到 CPU 上下文切换、内存分配等工作。

  2. 线程池本身会有参数来控制线程创建的数量,易于管理,可以避免无休止的创建线程带来的资源消耗过高的问题。

线程池里面用到了阻塞队列,简单来说就是线程池里面的工作线程处于一直运行状态,它会从阻塞队列中去获取待执行的任务,一旦队列空了,那这个工作线程就会被阻塞,直到下次有新的任务进来。 也就是说,工作线程是根据任务的情况实现阻塞和唤醒,从而达到线程复用的目的。

阻塞队列

最后,线程池里面的资源限制,是通过几个关键参数来控制的,分别是核心线程数(长期工)、最大线程数(临时工)。

Last updated