news 2026/4/16 12:16:30

异步CompletableFuture最常用的用法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
异步CompletableFuture最常用的用法

下面用「核心场景 + 极简代码 + 一句话说明」的形式,把CompletableFuture最常用的用法拆得更清晰,只保留核心逻辑,去掉冗余:

一、最基础:创建异步任务(核心中的核心)

场景 1:无返回值(比如广告统计、日志记录)
// 推荐:自定义线程池(避免默认池耗尽) Executor pool = Executors.newFixedThreadPool(3); CompletableFuture.runAsync(() -> { // 要异步执行的代码(比如统计广告数据) System.out.println("异步执行无返回值任务"); }, pool); // 极简版(临时测试用) CompletableFuture.runAsync(() -> System.out.println("异步执行无返回值任务"));

一句话:runAsync+ 任务代码 + (可选)自定义线程池,执行完就结束,不用返回结果。

场景 2:有返回值(比如异步查数据库、调接口)
Executor pool = Executors.newFixedThreadPool(3); CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> { // 异步执行并返回结果(比如查数据库返回字符串) return "异步任务的返回结果"; }, pool); // 极简版 CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> "返回结果");

一句话:supplyAsync+ 有返回值的代码,能拿到异步任务的结果。

二、拿到结果后:怎么处理(链式操作)

CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> "hello"); // 1. 转换结果(比如把hello变成hello world) future.thenApply(str -> str + " world"); // 有返回值 // 2. 消费结果(比如打印、存日志,不用返回) future.thenAccept(str -> System.out.println("拿到结果:" + str)); // 无返回值 // 3. 任务完事后执行(不管结果,比如弹个提示) future.thenRun(() -> System.out.println("任务执行完了")); // 无返回值

一句话:

  • thenApply:改结果、有返回;
  • thenAccept:用结果、无返回;
  • thenRun:只执行、不关心结果。

三、多任务配合:多个异步任务怎么协同

CompletableFuture<String> task1 = CompletableFuture.supplyAsync(() -> "任务1结果"); CompletableFuture<Integer> task2 = CompletableFuture.supplyAsync(() -> 2); // 1. 串联执行(任务1的结果传给任务2) task1.thenCompose(res1 -> CompletableFuture.supplyAsync(() -> res1 + "-任务2")); // 2. 合并结果(任务1和任务2都做完,合并结果) task1.thenCombine(task2, (res1, res2) -> res1 + res2); // 结果:任务1结果2 // 3. 等所有任务做完(比如批量处理10个异步任务) CompletableFuture.allOf(task1, task2).join(); // 阻塞等task1、task2都完成 // 4. 只要有一个任务做完(比如多接口抢结果) CompletableFuture.anyOf(task1, task2); // 谁先做完就用谁的结果

一句话:

  • thenCompose:任务串着来;
  • thenCombine:任务并行做、合并结果;
  • allOf:等所有任务;
  • anyOf:等第一个完成的任务。

四、必加:异常处理(避免异步异常丢了)

CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> { throw new RuntimeException("任务出错了"); // 模拟异常 }); // 1. 异常兜底(出错了返回默认值) future.exceptionally(e -> { System.err.println("捕获异常:" + e.getMessage()); return "出错后的默认值"; // 异常时返回这个值 }); // 2. 完成回调(不管成功/失败都执行) future.whenComplete((res, e) -> { if (e != null) { System.err.println("任务失败:" + e.getMessage()); } else { System.out.println("任务成功:" + res); } });

一句话:

  • exceptionally:出错了给个兜底值;
  • whenComplete:成功 / 失败都能处理。

五、最后:怎么拿结果(尽量少阻塞)

CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> "返回结果"); // 1. 阻塞拿(简单,推荐用这个) String res1 = future.join(); // 出错抛运行时异常,不用try-catch // 2. 超时拿(防止卡死,更安全) String res2 = future.get(1, TimeUnit.SECONDS); // 1秒拿不到就抛超时异常,需try-catch // 3. 非阻塞拿(拿不到就给默认值) String res3 = future.getNow("默认值"); // 任务没做完就返回"默认值"

一句话:

  • join():简单阻塞拿结果;
  • get(超时):防止无限等;
  • getNow():不阻塞,拿不到就兜底。

最终核心总结(记这几句就够)

  1. 无返回值异步:runAsync(任务, 线程池)
  2. 有返回值异步:supplyAsync(任务, 线程池)
  3. 处理结果:转结果用thenApply、用结果用thenAccept
  4. 多任务:串着做thenCompose、合并结果thenCombine、等全部allOf
  5. 异常:必加exceptionally/whenComplete
  6. 拿结果:优先join()(简单)或get(超时)(安全)。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 10:40:07

别让多微信“拖垮”效率!这个系统让多号管理像用单号一样轻松

核心客户一个号、项目协作一个号、渠道业务又一个号——职场人手里的微信越来越多&#xff0c;麻烦也跟着来。 切号要反复验证&#xff0c;输密码、收验证码耗半天&#xff1b;多个窗口堆一起&#xff0c;消息发错账号差点丢客户&#xff1b;想找上周的聊天记录&#xff0c;得在…

作者头像 李华
网站建设 2026/4/16 11:14:26

MATLAB句柄函数(函数句柄)详解

目录 MATLAB句柄函数(函数句柄)详解 📌 什么是函数句柄? 🎯 基本语法 1. 创建函数句柄 2. 调用函数句柄 🔧 匿名函数详解 基本形式 捕获外部变量 带参数检查的匿名函数 🚀 函数句柄的高级用法 1. 作为函数参数传递 2. 在优化和数值计算中的应用 3. 事件…

作者头像 李华
网站建设 2026/4/15 23:05:14

​​HeapDump​​在线工具:告别JVM参数烦恼

逛社区发现一个在线工具 HeapDump , 地址 https://opts.console.heapdump.cn/ 。它能帮助Java开发者快速生成JVM参数配置&#xff0c;解决手动配置的痛点。 工具核心能力 由前阿里资深JVM专家开发&#xff0c;专为解决Java服务部署时配置-Xms、-Xmx等参数的难题。根据输入的机…

作者头像 李华
网站建设 2026/4/10 1:30:18

Spark-Store终极指南:Linux软件管理完整教程

Spark-Store终极指南&#xff1a;Linux软件管理完整教程 【免费下载链接】星火应用商店Spark-Store 星火应用商店是国内知名的linux应用分发平台&#xff0c;为中国linux桌面生态贡献力量 项目地址: https://gitcode.com/spark-store-project/spark-store 还在为Linux系…

作者头像 李华
网站建设 2026/4/14 2:47:28

探索 Buck DCDC:自适应恒定导通时间控制的降压变换器之旅

Buck DCDC&#xff08;自适应恒定导通时间控制&#xff09; 正向设计的降压变换器&#xff0c;适合刚开始学习电源方向的同学拿来参考使用&#xff0c;环路响应速度快。 使用PWM/PFM双模式调制&#xff0c;可实现无缝衔接的模式切换 输入电压1.6&#xff5e;1.8V &#xff0c;…

作者头像 李华
网站建设 2026/4/13 7:54:49

数据库高可用架构:主从复制、集群与分片技术的综合应用

数据库作为企业业务系统的核心引擎&#xff0c;其可用性直接决定业务连续性。随着业务数据量激增&#xff08;如日均交易超百万笔、数据量达TB级&#xff09;&#xff0c;单节点数据库面临“性能瓶颈”“单点故障”“容量上限”三大挑战——某电商企业曾因数据库单点宕机导致订…

作者头像 李华