CompletableFuture 异步处理相关(list)集合数据

本文介绍Java中CompletableFuture类的基本用法,包括supplyAsync方法的两种形式及其执行方式。此外,还提供了如何利用CompletableFuture.allOf进行多个任务的等待示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CompletableFuture类实现了CompletionStage和Future接口

public class CompletableFuture<T> implements Future<T>, CompletionStage<T>

    public static <U> CompletableFuture<U> supplyAsync(Supplier<U> supplier) {
        return asyncSupplyStage(asyncPool, supplier);
    }

方法的参数类型都是函数式接口,所以可以使用lambda表达式实现异步任务我们可以像Future那样使用它

public static <U> CompletableFuture<U> supplyAsync(Supplier<U> supplier, Executor executor)

方法的参数类型都是函数式接口,所以可以使用lambda表达式实现异步任务,返回值是经过转化后结果

CompletableFuture.allOf(futureList.toArray(new CompletableFuture[]{})).join();

注:在使用中发现问题,Async结尾的方法都是可以异步执行的,如果指定了线程池,会在指定的线程池中执行,如果没有指定,默认会在ForkJoinPool.commonPool()中执行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值