java 异步 future_Java中CompletableFuture处理异步超时的例子

CompletableFuture是java8中添加的一个类了,这个类主要的作用就是提供了新的方式来完成异步处理,包括合成和组合事件的非阻塞方式了,下文我们就来重点的为各位介绍一下异步超时处理例子,希望例子能够帮助到各位。

Java是一种可以撰写跨平台应用软件的面向对象的程序设计语言。Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。

public void serve() throws InterruptedException, ExecutionException, TimeoutException {

final Future responseFuture = asyncCode();

final Response response = responseFuture.get(1, SECONDS);

send(response);

}

private void send(Response response) {

//...

}

这是用Java写的一个Akka应用程序,使用了一个包含1000个线程的线程池(原来如此!)——所有的线程都在阻塞在这个 get() 中。系统的处理速度跟不上并发请求的数量。重构以后,我们干掉了所有的这些线程仅保留了一个,极大的减少了内存的占用。我们简单一点,通过一个Java 8的例子来演示。第一步是使用CompletableFuture来替换简单的Future(见:Tip 9)。

通过控制任务提交到ExecutorService的方式:只需用 CompletableFuture.supplyAsync(…, executorService) 来代替

你可能感兴趣的:(java,异步,future)