背景
线程池是什么
线程池(Thread Pool)是一种基于池化思想管理线程的工具,经常出现在多线程服务器中,或者涉及到一些复杂线程操作需要重复开启线程。线程过多会带来额外的开销,包括创建线程的开销,调度线程的开销等等,同时也降低了计算机的整体性能。
线程池能维护多个线程,等待监督管理分配可并发执行的任务,这种做法一方面避免了处理任务时创建销毁线程开销的代价,另一方面也避免了线程数量膨胀的过分调度问题,保证了对内核的充分利用。
Java中对线程池的实现都是基于ThreadPoolExcutor类,它能带来一系列的好处:
- 降低资源消耗: 通过池化技术重复利用已经创建的线程,降低线程创建和销毁造成的损耗
- 提高响应速度: 任务到达时,无需等待线程创建就可以立即执行(前提是线程池中有可用的线程)
- 提高线程的可管理性: 线程是稀缺资源,如果无限制创建,不仅会消耗系统资源,还会因为线程的不合理分布导致资源调度失衡,降低系统的稳定性。使用线程池可以进行统一的分配、调优和监控。不用开发者自己去维护这一整个流程。
- 提供更多更强大的功能: 线程池具备可拓展性,允许开发人员向其中增加更多的功能。比如延时定时线程池ScheduledThreadPoolExecutor,就允许任务延期执行或定期执行。