在JDK5中增加了Future异步获取结果的功能,但是这种方式在获取的时候是阻塞的,在正常场景下这种实现方式肯定是不太友好的,当然可以通过轮询的方式去获取异步结果,但是这种方式比较消耗CPU并且获取结果也不会太及时,所以也不提倡使用;在jdk7中提供了CompletionService的take和pool方法,来获取执行的结果;jdk8中的CompletableFuture也是非常强大的实现了异步回调的功能;另外很多开源框架自己也实现了异步回调功能,像Netty的channelFuture,通过addListener来实现异步回调的编程方式;Guava也是同样的通过ListenableFuture实现了异步回调的编程方式。
下面主要介绍下jdk8中的CompletableFuture的使用方式以及Guava的使用方式:
一、jdk8中的CompletableFuture实现异步回调方式,话不多说,直接上代码:
/**
* JDK CompletableFuture异步回调测试
*
*/
public class JdkCompletableFutureTest {
public static void main(String[] args) throws Exception {
ExecutorService executor = ExecutorServiceSupport.newTheadPool("guava_future_test");
testThenApply(executor);
testThenAccept(executor);
testExceptionally(executor);
testWhenComplete2HaveValue(executor);
testWhenComplete2Exception(executor);
}
/**
* 对结果进行转换
* @param executor
*/
public stati

本文探讨了Java中使用Future实现异步回调的方法,包括JDK5的阻塞获取、JDK7的CompletionService以及JDK8的CompletableFuture。重点介绍了CompletableFuture和Guava的ListenableFuture如何实现异步回调,通过代码示例展示了它们的使用方式。
最低0.47元/天 解锁文章
2736

被折叠的 条评论
为什么被折叠?



