链接地址:http://www.xx566.com/detail/163.html
Futures是Guava Concurrency提供的用于处理Future实例的工具类,其中提供了需要有用方便的方法,一些方法的使用也有特定的场景,之前的学习中,我们提到 了AsyncFution和FutureFallback,本篇我们重点来学习一些与之相关的方法:AsyncFunctions 以及FutureFallbacks。
之前的学习中,我们已经学习到了Futures的一些方法,如:Futures.addFallback,用于注册一个FutureCallback实例,在ListenableFuture实例完成其任务后执行。
异步转换
Guava库学习:学习Concurrency(六)AsyncFunction中,我们学习了AsyncFunction接口,以及如何接收Fuction进行异步的转换,Futures提供了transform方法,使我们能够简便的使用AsyncFunction接口:
@Test public void testFuturesTransform() throws ExecutionException, InterruptedException { listenableFuture = executorService.submit(new Callable<String>() { @Override public String call() throws Exception { return "张三"; } }); AsyncFunction<String, Person> asyncFunction = new AsyncFunction<String, Person>() { @Override public ListenableFuture<Person> apply(String input) throws Exception { person.setName(input); return executorService.submit(new Callable<Person>() { @Override public Person call() throws Exception { return person; } }); } }; ListenableFuture<Person> lf = Futures.transform(listenableFuture, asyncFunction); assertThat(lf.get().getName(), is("张三")); }
Futures.transform方法返回了一个ListenableFuture实例,其结果是通过对从传递到方法中的ListenableFuture的执行结果进行一个异步的转换。
FutureFallbacks的应用
Guava库学习:学习Concurrency(七)FutureFallback中,我们同样学习了FutureFallback接口,能够帮助我们处理ListenableFuture执行出现的错误信息,Futures.withFallback方法使用类似的方法注册FutureFallback,我们可以像下面这样使用:
@Test public void testFuturesFallback() throws ExecutionException, InterruptedException { listenableFuture = executorService.submit(new Callable<String>() { @Override public String call() throws Exception { throw new RuntimeException(); } }); FutureFallback<String> futureFallback = new FutureFallback<String>() { @Override public ListenableFuture create(Throwable t) throws Exception { if (t instanceof RuntimeException) { SettableFuture<String> settableFuture = SettableFuture.create(); settableFuture.set("Not Found"); return settableFuture; } throw new Exception(t); } }; ListenableFuture<String> lf = Futures.withFallback(listenableFuture,futureFallback); assertThat(lf.get(), is("Not Found")); }
Futures.withFallback方法返回了一个ListenableFuture实例,其接收一个listenableFuture参数和 futureFallback参数,如果给定的listenableFuture执行成功,则返回成功的结果,如果失败,则返回 FutureFallback中设置的错误信息。
接下来,我们翻开Futures的源码,简单的整理一下其中的公共方法,如下:
makeChecked( ListenableFuture<V> future, Function<Exception, X> mapper):根据传入ListenableFuture和Function构建一个CheckFuture,映射异常的实例到相应的检查类型。
immediateFuture(@Nullable V value):创建一个设置value值的ListenableFuture,其value值立即会被设置,getter方法只是返回值。这个 Future不能取消或超时,Future的isDone()方法总是返回true。
immediateFailedFuture( Throwable throwable):返回一个构造时设置传入异常的ListenableFuture,返回的Future不能被取消,isDone()方法总是返回 true,调用get()方法会抛出被ExecutionException包装的Throwable。
immediateCancelledFuture():创建一个会被立即取消的ListenableFuture,所以isCancelled()方法总是返回true。
immediateCheckedFuture(@Nullable V value):返回一个CheckedFuture,构造时其value值立即会被设置,返回的Future不能被取消,isDone()方法总是返回 true,调用get()或者checkGet()方法会立即返回设置的value值。
immediateFailedCheckedFuture(X exception):返回一个构造时设置传入异常的CheckedFuture,返回的Future不能被取消,isDone()方法总是返回 true,调用get()方法会抛出被ExecutionException包装的Exception,调用checkGet()方法会抛出给定的 exception异常。
withFallback( ListenableFuture<? extends V> input, FutureFallback<? extends V> fallback):返回一个Future,其结果来自于ListenableFuture,如果ListenableFuture出现失败,则结果由给 定的FutureFallback产生。
withFallback( ListenableFuture<? extends V> input, FutureFallback<? extends V> fallback, Executor executor):返回一个Future,其结果来自于ListenableFuture,如果ListenableFuture出现失败,则结果由给 定的FutureFallback产生,并由给定的executor提供线程单独运行FutureFallback。
transform(ListenableFuture<I> input, AsyncFunction<? super I, ? extends O> function):创建一个新的ListenableFuture,它的结果异步来自于给定ListenableFuture的结果,更准确的说,返回 的结果是由原始的结果应用给定的function后的结果。
transform(ListenableFuture<I> input, AsyncFunction<? super I, ? extends O> function, Executor executor):创建一个新的ListenableFuture,它的结果异步来自于给定ListenableFuture的结果,更准确的说,返回 的结果是由原始的结果应用给定的function后的结果,给定的function操作由executor执行。
transform(ListenableFuture<I> input, final Function<? super I, ? extends O> function):创建一个新的ListenableFuture,它的结果是给定input ListenableFuture的结果应用给定的function后的结果。
transform(ListenableFuture<I> input, final Function<? super I, ? extends O> function, Executor executor):创建一个新的ListenableFuture,它的结果是给定input ListenableFuture的结果应用给定的function后的结果,给定的function操作由executor执行。
lazyTransform(final Future<I> input, final Function<? super I, ? extends O> function):与transform方法类似,不过function的转换过程会每次调用返回的Future的get()方法。
dereference( ListenableFuture<? extends ListenableFuture<? extends V>> nested):返回一个新的ListenableFuture,它的结果是给定nested ListenableFuture调用get()的结果, 此方法能够有效的将一个ListenableFuture链接到另一个ListenableFuture。
allAsList( ListenableFuture<? extends V>... futures):创建一个新的ListenableFuture,当给定的futures集合中future都完成时返回结果的list,如果任一 future失败,则创建的ListenableFuture会失败。
allAsList( Iterable<? extends ListenableFuture<? extends V>> futures):创建一个新的ListenableFuture,当给定的futures集合中future都完成时返回结果的list,如果任一 future失败,则创建的ListenableFuture会失败。
nonCancellationPropagating( ListenableFuture<V> future):创建一个新的ListenableFuture,当给定的future完成时,它的结果才会被设置。取消给定的future也会取消返回 的ListenableFuture,但是取消返回的ListenableFuture对给定的future没有影响。
successfulAsList( ListenableFuture<? extends V>... futures):创建一个新的ListenableFuture,它的值是一个列表包含所有传入Future集合中Future执行成功后返回的值,结 果的顺序与传入集合的顺序一致,如果任何一个传入集合中的Future失败或被取消,其对应的位置的值将会被设置为null,(这导致了将无法区别执行成 功后返回值为null的任务)。
successfulAsList( Iterable<? extends ListenableFuture<? extends V>> futures):创建一个新的ListenableFuture,它的值是一个列表包含所有传入Future集合中Future执行成功后返回的值,结 果的顺序与传入集合的顺序一致,如果任何一个传入集合中的Future失败或被取消,其对应的位置的值将会被设置为null,(这导致了将无法区别执行成 功后返回值为null的任务)。
inCompletionOrder( Iterable<? extends ListenableFuture<? extends T>> futures):返回一个委托的Future的列表,对应Future完成的顺序,委托的Future会返回相同的值或者抛出相同的异常,和原生的 Future一致。
addCallback(ListenableFuture<V> future, FutureCallback<? super V> callback):注册一个在任务成功或失败时运行的回调函数,一旦Future完成,则立即执行回调函数。
addCallback(final ListenableFuture<V> future, final FutureCallback<? super V> callback, Executor executor):注册一个在任务成功或失败时单独运行的回调函数,这个单独操作Callback的线程由传入的executor提供,一旦 Future完成,则立即执行回调函数。
get( Future<V> future, Class<X> exceptionClass):返回Future.get()的结果,转换大部分的异常为新给定的异常类型,这样减少了大量的代码,对异常代码不必要的区分类型。
get( Future<V> future, long timeout, TimeUnit unit, Class<X> exceptionClass):返回Future.get(long,TimeUnit)的结果,转换大部分的异常为新给定的异常类型,这样减少了大量 的代码,对异常代码不必要的区分类型。
getUnchecked(Future<V> future):返回Future.get()的结果,这个结果不会阻塞任务也不抛出被检查出的异常,这使得任务执行更轻量级,更快速运行,除非是遇到代码bug,否则不会失败。
总结:Futures是强大的操作Future的工具类,不过其中的一些方法目前自己的理解还不清晰,其中的一些方法也没有用到,还需要在以后的工作和学习中,反复思考,反复总结。学无止境。
代码地址:http://git.oschina.net/realfighter/xx566-diary/blob/master/src/guava/FuturesTest.java