推荐直接使用ThreadPoolExecutor自定义线程池而非Executors工厂方法,因其可明确控制核心线程数、最大线程数、有界队列、拒绝策略等关键参数,避免无界队列OOM和无限创建线程等生产风险。
Java中通过 Executors 工具类可以快速创建常见类型的线程池,但要注意:这些工厂方法封装了 ThreadPoolExecutor,底层逻辑固定,灵活性低,生产环境更推荐直接使用 ThreadPoolExecutor 构造器自定义参数。
以下是 JDK 提供的几个典型静态工厂方法,各自封装了不同配置的线程池:
主要原因在于隐藏风险:
明确指定核心线程数、最大线程数、空闲存活时间、有界阻塞队列、拒绝策略等,提升可控性和健壮性。例如:
(示例代码逻辑,非可运行片段)
new ThreadPoolExecutor(
2, // 核心线程数
8, // 最大线程数
60L, // 空闲线程存活时间
TimeUnit.SECONDS,
new ArrayBlockingQueue(100), // 有界队列,容量100
new ThreadFactoryBuilder().setNameFormat("biz-task-%d").build(),
new ThreadPoolExecutor.CallerRunsPolicy() // 拒绝策略:由提交线程自己执行);
学习阶段或简单脚本中,用 Executors 快速上手没问题;但真实业务系统必须关注资源边界、拒绝行为和可观测性。把线程池当成“黑盒”调用,迟早会在线上出问题。本质上,Executors 是教学友好型封装,不是生产就绪型方案。
基本上就这些。