异步任务
什么是 CompletableFuture
在 Java 8 中引入了 CompletableFuture用于异步编程,异步通常意味着非阻塞,可以使我们的任务单独运行在与主线程分离的其他线程中,并通过回调可以在主线程中得到异步任务的执行状态,是否完成和异常信息等。
CompletableFuture除了提供更为好用和强大的Future特性之外,还提供了函数式编程、异步任务编排组合(将多个异步任务串联起来,组成一个完整的链式调用)等能力,提升了异步编程模型。
为什么要引入CompletableFuture
在一些业务场景中我们需要使用多线程异步执行任务,加快任务执行速度,所以JDK5新增了Future接口,用于描述一个异步计算的结果。
虽然Future提供了一步执行任务的能力,但是Future在实际使用过程中存在着一些局限性,比如不支持异步任务的编排组合、获取计算结果的get()方法为阻塞调用。或者通过轮询的方式判断Future.isDone任务是否结束,在获取结果。
ExecutorService executorService = Executors.newSingleThreadExecutor();
Future<String> future = executorService.submit(() -> {
Thread.sleep(2000);
return "hello world";
});
while (true) {
if (future.isDone()) {
System.out.println(future.get());
break;
}
}CompletableFuture 使用
线程串行化
其中thenApply是同步的,thenApplyAsync是异步的。
运行结果如下:
如果将thenApply换成thenApplyAsync,任务将在子线程执行,执行结果如下:
这两个方法的区别在于谁去执行这个任务,如果使用thenApplyAsync,那么执行的线程是从ForkJoinPool.commonPool()中获取不同的线程进行执行,如果使用thenApply,runAsync方法执行速度特别快,那么thenApply任务就是主线程进行执行,如果执行特别慢的话就是和runAsync执行线程一样。
thenApplyhe和thenApplyAsync的区别:
执行结果如下:
可以看到,如果runAsync方法执行速度慢的话,thenApply方法执行线程和runAsync执行线程相同,如果runAsync执行速度快的话,那么thenApply方法执行线程和Main方法执行线程相同
runAfterBoth:
thenCombine
异常处理
CompletableFuture allOf 获取所有线程结果
两个任务组合
多任务组合
https://mikechen.cc/15629.html
https://blog.csdn.net/li1325169021/article/details/126494107
最后更新于
这有帮助吗?