赞
踩
CompletableFuture类的源码描述:
一个可以显式完成(设置其值和状态),可以用作CompletionStage,支持在其完成时触发依赖函数和操作的CompletableFuture。(看命令就知道是Future的补充类)
当两个或更多线程尝试去调用一个CompletableFuture实例的#complete,#completeExceptionally,#cancel方法时,只会有一个会成功。
此外,除了这些和与直接操纵状态和结果相关的方法外,CompletableFuture根据以下策略实现了CompletionStage接口:
1.所有没有指定Executor的异步方法都是使用ForkJoinPool#commonPool()来执行。除非它不支持至少两级的并行级别,在种情况下,会创建一个新线程
来运行每个任务)。
2.为了简化监控、调试和跟踪,所有生成的异步任务是标记接口AsynchronousCompletionTask的实例。
3.CompletionStage被实现的方法都是独立于其他public方法的。因此,一个方法的行为不会受到其他子类的影响。
CompletableFuture同样根据以下策略实现了Future:
1.因为(不像{@link FutureTask}),这个类不能直接控制计算的完成,取消被视为另一种特殊形式的完成。#cancel方法和completeExceptionally
(new CancellationException())是一样的作用。#isCompletedExceptionally用来判断CompletableFuture是否是以任何
特殊的方式完成的。
2.在以CompletionException异常完成的情况下,#get()和#get(long, TimeUnit)会抛出一个ExecutionException异常。为了可以在
大多数情况下简单使用,CompletableFuture定义了#join()和在这些情况下直接抛出CompletionException异常的#getNow方法。
使用:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。