“兄弟,听说你最近在面试 Java 开发?”
“是啊,昨天刚面了个大厂,结果一上来就问我线程池的创建方式,差点没给我问懵了……”
“线程池啊?这可是 Java 多线程编程的必考点啊!不过你别慌,今天咱们就来系统地复习一下这个知识点,保证你下次遇到这种问题,稳稳拿下!”
什么是线程池?
在正式聊线程池之前,我们先来看看下面这个场景。
假设你是一家餐厅的老板,生意火爆,每天都有大量顾客上门点餐。如果你让每位顾客进店时都临时招聘一个厨师来做饭,那不仅招聘成本高,厨师培训慢,顾客等得也烦。有没有更好的办法呢?
当然有!你可以雇佣一支固定的厨师团队,来回轮流做饭。这样不仅节省了招聘时间,还能让厨师们各司其职,提高效率。
在 Java 里,线程池(ThreadPool)就类似于这个厨师团队的概念。它的作用是:
- 预先创建一批线程,并复用它们来执行任务,避免频繁创建和销毁线程带来的开销。
- 统一管理线程,提高线程的调度效率。
- 控制并发量,防止系统因创建过多线程导致崩溃。
总结一下,线程池的本质就是管理和复用一批线程,以提高系统的并发性能并降低线程创建的开销。
线程池的创建方式
在 Java 里,线程池主要是由 ExecutorService 接口提供的,而 ThreadPoolExecutor 是它的核心实现类。创建线程池的方式主要有以下几种: