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

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()中执行

经验分享 程序员 微信小程序 职场和发展