0

0

Java并发编程中的ExecutorService应用

P粉602998670

P粉602998670

发布时间:2026-01-10 14:17:27

|

384人浏览过

|

来源于php中文网

原创

Future.get()卡住的根本原因是任务未结束或被I/O、锁等阻塞;其为同步阻塞调用,不主动中断任务;cancel(true)仅靠任务响应中断信号才生效,否则无效。

java并发编程中的executorservice应用

ExecutorService.submit() 返回的 Future 为什么有时 get() 会卡住

根本原因是任务本身没结束,或者被阻塞在 I/O、锁、无限循环里,Future.get() 是同步阻塞调用,它不会主动中断正在运行的任务。

  • 默认情况下,ExecutorService 不会因 Future.cancel(true) 就强制终止线程——JVM 不支持真正“杀掉”线程,只能靠任务自己响应 Thread.interrupted()
  • 如果任务中用了 Object.wait()Thread.sleep() 或可中断的 NIO 操作,cancel(true) 才会生效并抛出 InterruptedException
  • 常见陷阱:提交了一个无超时的 get(),而任务因数据库连接超时未设 timeout,结果主线程永久挂起

稳妥做法是始终带超时:

try {
    result = future.get(3, TimeUnit.SECONDS);
} catch (TimeoutException e) {
    future.cancel(true); // 尝试中断
    throw new RuntimeException("Task timed out", e);
}

shutdown() 和 shutdownNow() 的实际行为差异

shutdown() 是温柔退场:拒绝新任务,但允许已提交的(包括队列里排队的)任务继续执行完;shutdownNow() 是硬中断:尝试中断所有正在执行的任务,并清空任务队列,返回尚未执行的任务列表。

  • shutdownNow() 并不保证任务立刻停止——它只是对每个工作线程调用 Thread.interrupt(),能否响应取决于任务代码是否检查中断状态
  • 如果任务正持有 synchronized 锁或在 native 方法中,中断信号会被忽略,线程仍会继续执行直到自然退出
  • 生产环境建议优先用 shutdown() + awaitTermination() 组合,留出合理等待窗口

典型安全关闭流程:

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

玻璃钢企业网站源码1.5
玻璃钢企业网站源码1.5

本程序源码为asp与acc编写,并没有花哨的界面与繁琐的功能,维护简单方便,只要你有一些点点asp的基础,二次开发易如反掌。 1.功能包括产品,新闻,留言簿,招聘,下载,...是大部分中小型的企业建站的首选。本程序是免费开源,只为大家学习之用。如果用于商业,版权问题概不负责。1.采用asp+access更加适合中小企业的网站模式。 2.网站页面div+css兼容目前所有主流浏览器,ie6+,Ch

下载
executor.shutdown();
try {
    if (!executor.awaitTermination(10, TimeUnit.SECONDS)) {
        executor.shutdownNow();
        if (!executor.awaitTermination(5, TimeUnit.SECONDS)) {
            System.err.println("Pool did not terminate gracefully");
        }
    }
} catch (InterruptedException e) {
    executor.shutdownNow();
    Thread.currentThread().interrupt();
}

FixedThreadPool 为什么不适合处理大量短时 IO 任务

因为它的核心线程数固定且永不回收,一旦任务涉及网络/磁盘 I/O,线程会长时间阻塞在 read()accept() 等系统调用上,导致线程资源被无效占用,吞吐量骤降。

  • FixedThreadPool 底层用的是 LinkedBlockingQueue(无界队列),任务持续涌入时,队列无限增长,可能引发 OOM
  • 替代方案应选 newCachedThreadPool()(适合大量短生命周期任务)或更可控的 newThreadPoolExecutor() 配合 SynchronousQueue 和自定义拒绝策略
  • 现代推荐:直接用 ForkJoinPool.commonPool() 处理 CPU 密集型任务;IO 密集型则交给 Netty、Vert.x 等异步框架,而非裸 ExecutorService

使用 CompletionService 统一收集异步结果的必要场景

当多个异步任务耗时差异大,又需要“谁先完成就先处理谁的结果”,而不是按提交顺序 get(),就必须用 CompletionService。否则你得维护一堆 Future,轮询或按序阻塞,效率低且易出错。

  • CompletionService 内部封装了阻塞队列(如 LinkedBlockingQueue),任务完成即入队,take() 总能拿到最先结束的那个
  • 注意:它不改变任务执行逻辑,只是结果获取方式更灵活;底层仍依赖传入的 ExecutorService
  • 别误以为它能“自动重试失败任务”——异常仍需在 future.get() 里显式捕获

简单用法示例:

ExecutorService executor = Executors.newFixedThreadPool(4);
CompletionService cs = new ExecutorCompletionService<>(executor);

for (int i = 0; i < 5; i++) { cs.submit(() -> { Thread.sleep(1000 * i); // 模拟不同耗时 return "result-" + i; }); }

for (int i = 0; i < 5; i++) { try { String result = cs.take().get(); // 按完成顺序获取 System.out.println(result); } catch (ExecutionException e) { e.printStackTrace(); } }

线程池不是万能胶,用错类型或忽略生命周期管理,比不用还危险。尤其要注意中断语义的脆弱性——它只是一次通知,不是指令。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

831

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

735

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

733

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

396

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16925

2023.08.03

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

25

2026.01.09

热门下载

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

精品课程

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

共23课时 | 2.4万人学习

C# 教程
C# 教程

共94课时 | 6.4万人学习

Java 教程
Java 教程

共578课时 | 44.4万人学习

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

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