Bootstrap

java给异步线程设置超时时间_Java中使用CompletableFuture处理异步超时

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) 来代替 executorService.submit(…) 即可

处理基于回调函数的API:使用promises

否则(如果你已经使用了阻塞式的API或 Future)会导致很多线程被阻塞。这就是为什么现在这么多异步的API都让人很烦了。所

;