首页 > Java > java教程 > 正文

ThreadPoolExecutor在java中创建线程池

舞姬之光
发布: 2025-12-05 12:14:40
原创
375人浏览过
推荐直接使用 ThreadPoolExecutor 而非 Executors,因其可显式配置核心线程数、最大线程数、队列容量和拒绝策略,避免 newCachedThreadPool 和 newFixedThreadPool 因无界队列导致的 OOM 风险。

threadpoolexecutor在java中创建线程池

ThreadPoolExecutor 是 Java 中最核心的线程池实现类,它提供了对线程池的精细控制能力,比 Executors 工厂方法更透明、更安全。

为什么推荐直接用 ThreadPoolExecutor 而不是 Executors?

Executors 提供的 newFixedThreadPool、newCachedThreadPool 等方法虽然写起来简单,但存在隐患:比如 newCachedThreadPool 使用无界队列(SynchronousQueue 实际上是“无缓冲”但配合无限线程数),可能引发 OOM;newFixedThreadPool 使用无界 LinkedBlockingQueue,任务堆积时内存持续增长。而 ThreadPoolExecutor 让你明确指定核心线程数、最大线程数、队列容量、拒绝策略等关键参数,避免隐式风险。

创建 ThreadPoolExecutor 的关键参数

构造函数有 7 个参数,最常用的是以下 4 个核心组合:

  • corePoolSize:核心线程数,即使空闲也不会被回收(除非 allowCoreThreadTimeOut=true)
  • maximumPoolSize:线程池允许的最大线程数,只有当队列满且当前线程数
  • keepAliveTime & unit:非核心线程空闲超时后被终止的时间
  • workQueue:用于保存待执行任务的阻塞队列,推荐使用有界队列(如 ArrayBlockingQueue)
  • threadFactory:用于创建新线程,建议自定义以统一命名和设置守护属性
  • handler:拒绝策略,常见有 AbortPolicy(抛异常)、CallerRunsPolicy(由提交线程自己执行)、DiscardPolicy(静默丢弃)、DiscardOldestPolicy(丢弃队首任务)

一个安全、可监控的创建示例

下面是一个生产环境推荐的写法:

多线程技术在iOS开发中的使用 WORD版
多线程技术在iOS开发中的使用 WORD版

本文档主要讲述的是多线程技术在iOS开发中的使用;所谓进程对应的是一个应用程序,负责开辟内存空间供应用程序使用,但是进程不能执行任务(指令)。一个进程至少包含一条线程,线程是程序的执行流。 iOS程序启动时,在创建一个进程的同时, 会开始运行一个线程,该线程被称为主线程;希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看

多线程技术在iOS开发中的使用 WORD版 0
查看详情 多线程技术在iOS开发中的使用 WORD版

立即学习Java免费学习笔记(深入)”;

ThreadFactory namedFactory = r -> {
    Thread t = new Thread(r, "biz-task-pool-" + System.currentTimeMillis());
    t.setDaemon(false);
    return t;
};

BlockingQueue<Runnable> queue = new ArrayBlockingQueue<>(1024);

ThreadPoolExecutor executor = new ThreadPoolExecutor(
    4,           // corePoolSize
    16,          // maximumPoolSize
    60L,         // keepAliveTime
    TimeUnit.SECONDS,
    queue,
    namedFactory,
    new ThreadPoolExecutor.CallerRunsPolicy() // 拒绝时由调用方执行,缓解压力
);
// 可选:启用线程池统计(如通过 JMX 或 Micrometer)
executor.prestartAllCoreThreads(); // 预热,避免首次任务延迟
登录后复制

使用中要注意的细节

  • 不要忘记在应用关闭时调用 shutdown()shutdownNow(),否则 JVM 无法正常退出
  • 监控 queue.size() 和 getActiveCount(),能及时发现任务积压或线程争用
  • 避免在线程池中执行阻塞 I/O 或长时间任务,应拆分或改用专用池
  • 慎用 allowCoreThreadTimeOut(true),它会让所有线程都可能被回收,适合流量波动极大的场景

基本上就这些。用好 ThreadPoolExecutor 不复杂,但容易忽略边界和生命周期管理。

以上就是ThreadPoolExecutor在java中创建线程池的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号