callable, callable, callable); List> futures = POOL.invokeAll(callables); } 在Java8...二、CompletableFuture 使用 1. runAsync、supplyAsync // 无返回值 public static CompletableFuture runAsync... runAsync = CompletableFuture.runAsync(() -> System.out.println(123)); CompletableFuture... supplyAsync = CompletableFuture.supplyAsync(() -> "CompletableFuture"); System.out.println...::println); // thenRun CompletableFuture thenRun = CompletableFuture.supplyAsync
如果子线程执行异常了会导致主线程长期阻塞,这其实是错误的,子线程执行异常时其异常会被捕获,然后修改任务的状态为异常结束并唤醒等待的主线程,get方法判断任务状态发生变更,就终止等待了,并抛出异常,可参考《Java8...的result是回调方法的执行结果或者回调方法执行期间抛出的异常,与原始CompletableFuture的result无关了。...CompletableFuture实例的result不为null,则返回一个基于该result的新的CompletableFuture实例;如果该CompletableFuture实例为null,则,然后执行这个新任务...4、allOf / anyOf allOf返回的CompletableFuture是多个任务都执行完成后才会执行,只有有一个任务执行异常,则返回的CompletableFuture执行get...cf4=CompletableFuture.allOf(cf,cf2,cf3).whenComplete((a,b)->{ if(b!
---- 概述 为了展示 CompletableFuture 的强大特性, 创建一个名为 best-price-finder 的应用,它会查询多个在线商店,依据给定的产品或服务找出最低的价格。...在这段代码中,创建了一个代表异步计算的 CompletableFuture 对象实例,它在计算完成时会包含计算的结果。...当请求的产品价格最终计算得出时,你可以使用它的 complete 方法,结束completableFuture 对象的运行,并设置变量的值。...为了让客户端能了解商店无法提供请求商品价格的原因,你需要使用 CompletableFuture 的 completeExceptionally 方法将导致 CompletableFuture 内发生问题的异常抛出...代码如下 【抛出CompletableFuture内的异常】 ?
于是在1.8的引入了CompletableFuture,他是针对future做了改进。通过example来看一下具体的使用 CompletableFuture的主要方法 1....CompletableFuture 提供了四个静态方法来创建一个异步操作。...public static CompletableFuture runAsync(Runnable runnable) public static CompletableFuture runAsyncDemo() { CompletableFuture voidCompletableFuture = CompletableFuture.runAsync... supplyAsyncDemo() { CompletableFuture stringCompletableFuture1 = CompletableFuture.supplyAsync
,anyOf包含多个CompletableFuture任务,只要任何一个任务完成,anyOf就返回一个新的CompletableFuture,allOf也是包含多个CompletableFuture任务...public static CompletableFuture anyOf(CompletableFuture<?...(CompletableFuture.java:357) at java.util.concurrent.CompletableFuture.get(CompletableFuture.java:1908...(CompletableFuture.java:357) at java.util.concurrent.CompletableFuture.get(CompletableFuture.java:1908...(CompletableFuture.java:357) at java.util.concurrent.CompletableFuture.get(CompletableFuture.java:1908
前面两篇文章已经整理了CompletableFuture大部分的特性,本文会整理完CompletableFuture余下的特性,以及将它跟RxJava进行比较。...3.6 Either Either 表示的是两个CompletableFuture,当其中任意一个CompletableFuture计算完成的时候就会执行。...CompletableFuture future1 = CompletableFuture.supplyAsync(() -> "tony"); CompletableFuture...CompletableFuture VS Java8 Stream VS RxJava1 & RxJava2 CompletableFuture 有很多特性跟RxJava很像,所以将CompletableFuture...先前的文章: Java8新的异步编程方式 CompletableFuture(一) Java8新的异步编程方式 CompletableFuture(二)
一、基本用法 1、创建 CompletableFuture 对象 CompletableFuture 可以通过以下方式进行创建: CompletableFuture future = new CompletableFuture...= CompletableFuture.supplyAsync(() -> 10); CompletableFuture future2 = CompletableFuture.supplyAsync...3、allOf() 和 anyOf() allOf() 方法接受一个 CompletableFuture 数组作为参数,等待所有的 CompletableFuture 都完成后返回: CompletableFuture...方法接受一个 CompletableFuture 数组作为参数,等待任意一个 CompletableFuture 完成后返回: CompletableFuture future1 =...CompletableFuture.supplyAsync(() -> 10); CompletableFuture future2 = CompletableFuture.supplyAsync
上一篇文章,讲述了Future模式的机制、缺点,CompletableFuture产生的由来、静态工厂方法、complete()方法等等。 本文将继续整理CompletableFuture的特性。...extends U>参数用来转换CompletableFuture,使用指定的线程池 thenApply的功能相当于将CompletableFuture转换成CompletableFuture、CompletableFuture和一个函数(T,U)->V,thenCompose就是将CompletableFuture和CompletableFuture...CompletableFuture future1 = CompletableFuture.supplyAsync(() -> "100"); CompletableFuture...CompletableFuture future1 = CompletableFuture.supplyAsync(() -> "100"); CompletableFuture
Java8主要的语言增强的能力有: (1)lambda表达式 (2)stream式操作 (3)CompletableFuture 其中第三个特性,就是今天我们想要聊的话题,正是因为CompletableFuture...什么是CompletableFuture?...简单的使用CompletableFuture 1,先看一个最简单的例子 在主线程里面创建一个CompletableFuture,然后主线程调用get方法会阻塞,最后我们在一个子线程中 使其终止。...CompletableFuture completableFuture=new CompletableFuture(); Runnable runnable...3,运行一个有返回值的异步任务 CompletableFuture future=CompletableFuture.supplyAsync(new Supplier()
:Future、Promise 和 Callback(在Java8之前,只有无Callback 的Future)。...CompletableFuture特性 3.1 CompletableFuture的静态工厂方法 方法名 描述 runAsync(Runnable runnable) 使用ForkJoinPool.commonPool...CompletableFuture future = CompletableFuture.runAsync(() -> { System.out.println("Hello...CompletableFuture future = CompletableFuture.supplyAsync(() -> "Hello"); try {...CompletableFuture future = CompletableFuture.supplyAsync(() -> "Hello"); future.complete
---- Pre Java8 - 使用CompletableFuture 构建异步应用 目前为止我们已经了解了如何通过编程创建 CompletableFuture 对象以及如何获取返回值,虽然看起来这些操作已经比较方便...,但还有进一步提升的空间, CompletableFuture 类自身提供了大量精巧的工厂方法,使用这些方法能更容易地完成整个流程,还不用担心实现的细节。...---- 使用工厂方法 supplyAsync创建 CompletableFuture 采用 supplyAsync 方法后,可以用一行代码重写getPriceAsync 方法。...,返回一个 CompletableFuture对象,该对象完成异步执行后会读取调用生产者方法的返回值。...> getPriceAsync(String product) { CompletableFuture futurePrice = new CompletableFuture();
Future 接口 的局限性有很多,其中一个就是需要主动的去询问是否完成,如果等子线程的任务完成以后,通知我,那岂不是更好?
JDK8引入中重磅类库:CompletableFuture Java8里面新增加了一个包含50个方法左右的类:CompletableFuture....使用案例 在Java8中,CompletableFuture提供了非常强大的Future的扩展功能,可以帮助我们简化异步编程的复杂性,并且提供了函数式编程的能力,可以通过回调的方式处理计算结果,也提供了转换和组合....thenApply(i -> i.toString()); //System.out.println(f.get()); //"1000" } 我们会发现,结合Java8...的计算值,返回结果将是一个新的CompletableFuture,这个新的CompletableFuture会组合原来的CompletableFuture和函数返回的CompletableFuture。...比如有这样一个需求,将多个CompletableFuture组合成一个CompletableFuture,这个组合后的CompletableFuture的计算结果是个List,它包含前面所有的CompletableFuture
super T> action) … 实现Future接口是为了能够得到数据 实现CompletionStage接口是为了能够流式处理 所以CompletableFuture封装了Future使其能够方法回调避免...get()阻塞线程或者while()循环对CPU不好 Future判断任务是否完成就是get()或者idDone()循环不是很好,而Completablefuture可以直接方法回调与链式编程很方便... future1 = CompletableFuture.runAsync(() -> System.out.println("runAsync"), Executors.newFixedThreadPool...(4)); CompletableFuture future2 = CompletableFuture.supplyAsync(() -> "supplyAsync", Executors.newFixedThreadPool...(4)); CompletableFuture.anyOf(future1, future2); CompletableFuture.allOf(future1, future2); future2.thenApply
📷 📷 📷
public void run() { LineUtils.print("原始异步Runnable"); } }); 现在咱们使用1.8的CompletableFuture... async = CompletableFuture.supplyAsync(() -> { System.out.println("1.8新版CompletableFuture...调用Callable"); return 1; }); final CompletableFuture future = CompletableFuture.runAsync...(CompletableFutureDemo::runnable, executor); CompletableFuture future = CompletableFuture...(future, future, future).get(); // 等待所有结果完成 CompletableFuture.allOf(future, future, future
因此,我们有必要了解CompletableFuture,同时其也是真正意义上的异步编程的实现。...package com.study.concurrent.completableFuture; import java.util.Random; import java.util.concurrent.CompletableFuture... future1 = CompletableFuture.supplyAsync(()-> "hello"); CompletableFuture future2...= CompletableFuture.supplyAsync(()-> "hello"); CompletableFuture result = future1.thenCombine...; } });*/ CompletableFuture f1 = CompletableFuture.supplyAsync((
public class CompletableFuture implements Future, CompletionStage 既然CompletableFuture类实现了CompletionStage...CompletableFuture提供了方法,能够显式地完成这个future,所以它叫CompletableFuture。...public static CompletableFuture runAsync(Runnable runnable) public static CompletableFuture completableFuture = CompletableFuture.supplyAsync(() -> { printTimeAndThread("厨师炒菜... completableFuture = CompletableFuture.supplyAsync(() -> { printTimeAndThread("厨师炒菜
CompletableFuture详解 回顾Future 因为CompletableFuture实现了Future接口所以先看一下Future Future是Java5新加的一个接口,它提供了一种异步并行计算的功能...实际上,它CompletableFuture使用了默认线程池是ForkJoinPool.commonPool。 CompletableFuture提供了几十种方法,辅助我们的异步任务场景。...CompletableFuture 创建异步任务 CompletableFuture创建异步任务,一般有supplyAsync和runAsync两个方法 supplyAsync执行CompletableFuture...任务,支持返回值 runAsync执行CompletableFuture任务,没有返回值。...thenRunAsync public CompletableFuture thenRun(Runnable action); public CompletableFuture
但是当你用过CompletableFuture之后,就会发现以前的线程池处理任务有多难用,功能有多简陋,CompletableFuture又是多么简洁优雅。...要知道CompletableFuture已经随着Java8发布7年了,还没有过它就有点说不过去了。今天5分钟带你深入浅出CompletableFuture实用教程。1....使用CompletableFuture重构任务处理看一下使用CompletableFuture改造后代码:/** * @author yideng * @apiNote CompletableFuture...十年前可以这样写,Java8都已经发布7年了,你还不会用Java8的写法?...别瞎想了,你写的肯定没有CompletableFuture好用,看一下CompletableFuture是怎么用的:/** * @author yideng * @apiNote CompletableFuture
领取专属 10元无门槛券
手把手带您无忧上云