0

0

在Java中如何使用Executor框架_Java线程池基本用法解析

P粉602998670

P粉602998670

发布时间:2026-01-30 12:37:51

|

767人浏览过

|

来源于php中文网

原创

生产环境应手动创建ThreadPoolExecutor,显式配置核心线程数、最大线程数、队列容量和拒绝策略;submit()适用于需结果和异常处理的场景,execute()仅执行无返回任务;shutdown后须调用awaitTermination等待任务完成。

在java中如何使用executor框架_java线程池基本用法解析

怎么创建一个能用的线程池

别一上来就写 new ThreadPoolExecutor(...),大多数场景直接用 Executors 工厂方法更安全。但要注意:它提供的几个静态方法有隐藏陷阱。

  • Executors.newFixedThreadPool(int) 底层用的是无界 LinkedBlockingQueue,任务堆积时可能 OOM
  • Executors.newCachedThreadPool() 允许无限创建线程,突发流量下容易耗尽系统资源
  • 生产环境推荐手动构造 ThreadPoolExecutor,显式控制核心线程数、最大线程数、队列容量和拒绝策略

例如启动一个最多 8 个线程、队列最多存 100 个任务、超时 60 秒自动回收空闲线程的池:

ThreadPoolExecutor executor = new ThreadPoolExecutor(
    4,           // corePoolSize
    8,           // maxPoolSize
    60L,         // keepAliveTime
    TimeUnit.SECONDS,
    new ArrayBlockingQueue(100),
    new ThreadPoolExecutor.CallerRunsPolicy()
);

submit() 和 execute() 到底该用哪个

区别不在“能不能跑”,而在“要不要结果”和“异常处理方式”。

  • execute(Runnable):只负责执行,不返回任何东西,如果任务抛出未捕获异常,会直接打印到 stderr,且无法被调用方感知
  • submit(Runnable)submit(Callable):返回 Future,可主动检查状态、获取结果、等待完成;异常会被包装进 Future.get() 抛出,便于集中处理
  • 如果你需要异步计算结果(比如查数据库后聚合),必须用 submit() + Callable

常见错误:用 execute() 提交可能抛异常的任务,又没配 ThreadFactory 设置 UncaughtExceptionHandler,导致异常静默丢失。

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

玄鲸Timeline
玄鲸Timeline

一个AI驱动的历史时间线生成平台

下载

线程池 shutdown 的正确姿势

不关干净会导致 JVM 不退出,或任务被丢弃却不通知。关键不是“调 shutdown”,而是“等完再停”。

  • 先调 shutdown():停止接收新任务,但会继续执行已提交和队列中的任务
  • 再调 awaitTermination(long, TimeUnit) 等待执行完成,建议设合理超时(如 30 秒)
  • 如果超时仍未结束,可考虑 shutdownNow() 尝试中断正在运行的任务(注意:不是所有任务都能被中断)

典型误操作:shutdown() 后立刻 return,没等任务结束,主线程就退出了。

拒绝策略选哪个才不丢任务也不卡死

当线程池满 + 队列满时触发,选错会导致数据丢失或线程阻塞。四种内置策略行为差异很大:

  • AbortPolicy(默认):直接抛 RejectedExecutionException,调用方必须处理,否则崩溃
  • CallerRunsPolicy:由提交任务的线程自己执行该任务,能自然降速,适合非关键任务
  • DiscardPolicy:静默丢弃,不报错,适合允许丢失的监控类任务
  • DiscardOldestPolicy:丢掉队列头任务,再尝试提交当前任务,有一定风险(可能反复丢老任务)

自定义策略可以记录日志、发告警、写入重试队列——但别在拒绝策略里做耗时操作(比如远程调用),会卡住 submit() 线程。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

463

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

544

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

113

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

200

2025.08.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

397

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

523

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

523

2023.08.10

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

8

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3万人学习

C# 教程
C# 教程

共94课时 | 8万人学习

Java 教程
Java 教程

共578课时 | 53.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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