当前位置: 首页 > news >正文

spring项目中业务逻辑涉及异步调用

两种异步模型的分叉点

@Async 和CompletableFuture.supplyAsync(() -> { … }) 正面对比

一、两种写法放一起看 👇
1️⃣ 你现在用的(Spring 推荐,企业级)
@Async
public void runTaskAsync(String pasaTaskId, String daHost, String runPath) {
// 异步逻辑
}

调用:

pasaAsyncService.runTaskAsync(…);

2️⃣ CompletableFuture 写法
CompletableFuture.supplyAsync(() -> {
// 异步逻辑
return result;
});

或:

CompletableFuture.runAsync(() -> {
// 无返回值
});

二、核心区别对比(重点)
对比点 @Async CompletableFuture.supplyAsync
线程池管理 ✅ Spring 统一管理 ❌ 默认 ForkJoinPool
是否推荐在 Spring 项目用 ✅ 强烈推荐 ⚠️ 有条件使用
AOP / 事务 / 安全上下文 ✅ 支持 ❌ 不支持
可读性 ✅ 清晰 ⚠️ 容易变复杂
任务编排 ❌ 一般 ✅ 非常强
异常处理 try-catch exceptionally / handle
适合场景 后台任务、接口触发 并行计算 / 流式处理
三、最关键的一点(90% 的坑)
❌ CompletableFuture 默认线程池是:
ForkJoinPool.commonPool()

问题:

❌ 和 JVM 里所有 CompletableFuture 共用

❌ 容易被 CPU 密集任务拖死

❌ 和 Spring 事务、日志 MDC、SecurityContext 无关

👉 在 Web 后台 / 微服务 中,不推荐直接用默认写法

四、如果你非要用 CompletableFuture,正确姿势是这样
✔ 指定线程池(否则不如不用)
CompletableFuture.runAsync(
() -> {
// 业务逻辑
},
pasaExecutor // Spring 注入的线程池
);

这样 本质上和 @Async 是一回事

五、结合你现在这个业务:该选哪个?
你的场景回顾

点击按钮 → 调 DA 接口

不关心返回值

不阻塞接口

需要日志、状态、可控线程

✅ 最优解(你现在的)
@Async
public void runTaskAsync(…) { … }

这是标准后台任务写法,没有任何问题

六、什么时候 CompletableFuture 更适合?
适合 CompletableFuture 的典型场景
CompletableFuture f1 = …
CompletableFuturef2 = …

CompletableFuture result =
f1.thenCombine(f2, (a, b) -> …)
.thenApply(…)
.exceptionally(…)

✔ 并行查询
✔ 聚合结果
✔ 链式处理
✔ 有返回值

👉 偏“计算 / 编排”

七、一句话结论

🔥 Spring 项目中:

接口触发、后台执行 → @Async

并行计算、结果编排 → CompletableFuture + 自定义线程池

❌ 永远不要在 Web 项目里裸用 CompletableFuture.supplyAsync()

http://www.jsqmd.com/news/172972/

相关文章:

  • Java CountDownLatch 代码示例:协调多个线程的执行顺序(比赛起跑)
  • 电气设备的发热量计算
  • 试过很多方法没用!怎么让孩子近视度数涨得慢些?
  • Segmentation Fault 调试指南:gdb + ASan + Valgrind 全流程实战
  • 微网优化调度:Matlab + Yalmip 实现之旅
  • 荣膺行业殊荣,iBox以数字科技激活文化传承新生态
  • MATLAB + 深度学习 = 心电图分类神器!完整流程 + 关键代码
  • 北京陪诊机构推荐守嘉陪诊:全链条护航让首都就医更从容 - 品牌排行榜单
  • 2025最新!自考党必看!10个AI论文平台测评与推荐
  • 不止是整理
  • UKB数据库/RAP平台批量下载数据教程
  • javaSE继承随笔
  • 做好孩子视力守护者预防“小眼镜”秘籍在这里
  • 智能一卡通系统配置清单包含管理中心设备、门禁、考勤、访客、通道闸机、梯控、停车场等九大子系统。核心设备包括服务器、管理平台、读卡器等,各子系统通过统一平台实现数据交互与权限管理
  • 云服务器 vs 传统服务器:核心区别与选型指南​
  • 云服务器成本管控:从粗放投入到精细运营
  • 智慧指挥中心建设厂商重磅盘点,成功案例+专业背书,itc保伦股份值得信赖 - 速递信息
  • Java+React全栈开发面试宝典(完整60题)
  • 云服务器架构演进:从虚拟化到容器化与无服务器的跨越
  • 云服务器架构演进:从虚拟化到容器化与无服务器的跨越
  • 2026年AI入门指南:四个学习平台的使用体验 - 速递信息
  • 墨香飘洋:当外国友人执起中国毛笔
  • 基于微信小程序的课程资料共享平台设计与实现
  • 回收站存在大量对象,导致Insert into...select语句夯住
  • 重磅签约!上海比孚携手 Dify,让企业 AI Agent 开发更简单、价值落地更高效
  • docker部署elk+filebeat日志收集分析系统
  • 科研牛马千万不要错过!手把手教你用AI精准匹配真实参考文献,仅需一个专业应用+两个提示词指令
  • 云服务器运维实战:从环境搭建到安全加固全流程​
  • iBox CEO宣松涛畅谈数字文创破局之道
  • Nginx 站点垂直扩容(单机性能升级)全攻略