CompletableFuture是什么?以及CompletableFuture的作用

文章目录

今天我们来聊聊 CompletableFuture

CompletableFuture

CompletableFuture 是 JDK1.8 里面引入的一个基于事件驱动的异步回调类。

简单来说,就是当使用异步线程去执行一个任务的时候,我们希望在任务结束以后触发一个后续的动作。

而 CompletableFuture 就可以实现这个功能。

举个简单的例子,比如在一个批量支付的业务逻辑里面,涉及到查询订单、支付、发送邮件通知这三个逻辑。

这三个逻辑是按照顺序同步去实现的,也就是先查询到订单以后,再针对这个订单发起支付,支付成功以后再发送邮件通知。

而这种设计方式导致这个方法的执行性能比较慢。

所以,这里可以直接使用 CompletableFuture,也就是说把查询订单的逻辑放在一个异步线程池里面去处理。

然后基于 CompletableFuture 的事件回调机制的特性,可以配置查询订单结束后自动触发支付,支付结束后自动触发邮件通知。

从而极大的提升这个这个业务场景的处理性能!

CompletableFuture 提供了 5 种不同的方式,把多个异步任务组成一个具有先后关系的处理链,然后基于事件驱动任务链的执行。

第一种,thenCombine,把两个任务组合在一起,当两个任务都执行结束以后触发事件回调。

第二种,thenCompose,把两个任务组合在一起,这两个任务串行执行,也就是第一个任务执行完以后自动触发执行第二个任务。

第三种,thenAccept,第一个任务执行结束后触发第二个任务,并且第一个任务的执行结果作为第二个任务的参数,这个方法是纯粹接受上一个任务的结果,不返回新的计算值。

第四种,thenApply,和 thenAccept 一样,但是它有返回值。

第五种,thenRun,就是第一个任务执行完成后触发执行一个实现了 Runnable接口的任务。

最后,我认为,CompletableFuture 弥补了原本 Future 的不足,使得程序可以在非阻塞的状态下完成异步的回调机制。

相关推荐
此木|西贝4 分钟前
【设计模式】原型模式
java·设计模式·原型模式
可乐加.糖21 分钟前
一篇关于Netty相关的梳理总结
java·后端·网络协议·netty·信息与通信
s91236010124 分钟前
rust 同时处理多个异步任务
java·数据库·rust
9号达人24 分钟前
java9新特性详解与实践
java·后端·面试
cg501728 分钟前
Spring Boot 的配置文件
java·linux·spring boot
啊喜拔牙36 分钟前
1. hadoop 集群的常用命令
java·大数据·开发语言·python·scala
anlogic1 小时前
Java基础 4.3
java·开发语言
非ban必选2 小时前
spring-ai-alibaba第七章阿里dashscope集成RedisChatMemory实现对话记忆
java·后端·spring
A旧城以西2 小时前
数据结构(JAVA)单向,双向链表
java·开发语言·数据结构·学习·链表·intellij-idea·idea
杉之2 小时前
选择排序笔记
java·算法·排序算法