一、什么是线程池
线程池是多线程处理中常用的一种模式。线程池创建多个线程,用于执行一堆任务,这些任务以队列的形式进行排列。这样可以很大程度上提高程序的运行效率,避免线程的创建和销毁带来的开销。
线程池一般包含以下几种主要构成部分:一个任务队列,一个或多个工作线程,一个线程创建和销毁的机制。在任务队列中存放的是待执行的任务,这些任务等待工作线程来执行。
二、线程池的作用
1、控制线程数量
线程池可以设定线程的最大并发数,避免大量的线程同时运行,耗尽系统资源。
2、复用线程
在线程池中,线程执行完任务后,不会立刻销毁,而是可以继续执行其他任务,因此可以减少线程的创建和销毁的开销。
三、线程池的问题
1、线程池大小的设定
线程池大小的设定需要根据实际任务的CPU时间,IO时间等因素综合考虑,没有一个固定的公式。
2、任务的排队策略
如果线程池中的所有线程都在执行任务,新来的任务如何处理也是需要考虑的问题,常见的策略有:直接拒绝任务,抛出异常;将任务放入队列,等待有空闲线程时执行;如果任务实现了某种接口,可以将任务抛回给调用者来执行。
延伸阅读
线程池优化
(1)合理配置线程池大小,可以根据系统的CPU的数量,IO密集型或者CPU密集型任务来合理配置。
(2)如果任务的执行时间过长,可以考虑任务的拆分。