Java8 CompletableFuture
java 8 新增CompletableFuture类简化异步编程的复杂性,提供函数式编程的能力,并且可以通过回调的方式处理计算结果。同时解决了
传统异步编程Future模式的缺点,对于异步执行结果,只能通过等待get操作以及轮询isDone去判断Future是否完成,是非常耗费CPU资源。而CompletableFuture
弥补了Future模式的缺点,在异步的任务完成后,需要用其结果继续操作时,无需等待。可以直接通过thenAccept、thenApply、thenCompose等方式
将前面异步处理的结果交给另外一个异步事件处理线程来处理。
本文将结束如下内容:
- CompletableFuture 常用API介绍
- CompletableFuture 与并行流区别
CompletableFuture 常用API介绍
主要分CompletableFuture创建、转换、消费、组合、错误处理等API使用。
CompletableFuture创建
public static CompletableFuture<Void> runAsync(Runnable runnable)
public static CompletableFuture<Void> runAsync(Runnable runnable, Executor executor)
public static <U> CompletableFuture<U> supplyAsync(Supplier<U> supplier)
public static <U> CompletableFuture<U> supplyAsync(Supplier<U> supplier, Executor executor)
public static <U> CompletableFuture<U> completedFuture(U value)
上面方法,没有带Executor参数,默认使用 ForkJoinPool.commonPool()线程池执行异步代码。如果带表示可以自定义线程池大小
代码示例:
public void testRunAsync() throws ExecutionException, InterruptedException {
CompletableFuture<Void> run = CompletableFuture.runAsync(() -> System.out.println("Hello World!"));
run.get();
}
public void testSupplyAsync()throws ExecutionException, InterruptedException {
ExecutorService service = Executors.newFixedThreadPool(10);
CompletableFuture<Cat> cat = CompletableFuture.supplyAsync(() -> new Cat("tom", "black"), service);
System.out.println(cat.get().getName());
}
public CompletableFuture<List<Cat>> testCompletedFuture() {
List<Cat> cats = Arrays.asList(new Cat("tom", "black"), new Cat("jack", "white")
, new Cat("lily", "black"));
return CompletableFuture.completedFuture(cats);
}
上面代码中runAsync是没有返回值,而supplyAsync以及completedFuture静态辅助方法是有返回值,通常使用他们构造CompletableFuture对象
CompletableFuture转换
public <U> CompletionStage<U> thenApply(Function<? super T,? extends U> fn);
public &l