java多线程——CompletableFuture

一、基本概述

CompletableFuture代表一个异步计算的结果,这个结果可以是已完成、正在进行或尚未开始的状态。它提供了一种灵活且类型安全的方式来表达异步操作的生命周期,包括创建、组合、处理结果以及处理异常。其设计灵感来源于函数式编程中的Promises/Futures模式,旨在简化异步编程模型,提高代码的可读性和可维护性。

二、创建方式

  1. 手动创建:通过new CompletableFuture<>()创建一个空的CompletableFuture对象,然后可以在其他地方手动完成它,例如使用complete(T value)方法。
  2. supplyAsync:该方法接收一个Supplier函数式接口,并异步执行它,然后返回包含其结果的CompletableFuture。可以使用默认的线程池(ForkJoinPool.commonPool()),也可以指定一个自定义的线程池。
  3. runAsync:与supplyAsync类似,但runAsync接收的是一个Runnable,它不返回任何结果。

三、链式调用

CompletableFuture支持链式调用,可以在一个任务完成后指定一系列的操作。这些操作可以是同步的,也可以是异步的。常见的链式调用方法包括:

  1. thenApply:在当前任务执行完成后,执行一个函数来处理返回值,并返回一个新的CompletableFuture。
  2. thenAccept:在当前任务执行完成后,获取结果并执行一个消费者函数,但不返回新的CompletableFuture(返回类型为CompletableFuture<Void>)。
  3. thenRun:在当前任务执行完成后,执行一个无参数的动作,不返回新的CompletableFuture(返回类型为CompletableFuture<Void>)。
  4. thenComposethenCombine:允许将多个CompletableFuture组合在一起,以某种方式处理它们的结果。

四、异常处理

CompletableFuture提供了对异常的处理能力,可以在异步操作出错时进行异常捕获和处理。常见的异常处理方法包括:

  1. exceptionally:当当前CompletableFuture因异常而未能正常完成时,应用给定的Function处理异常,并返回一个新的CompletableFuture,
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值