当前位置: 首页 > 面试题库 >

如何实现CompletableFuture.allOf(),一旦任何期货失效,它就会异常完成?

丁正阳
2023-03-14
问题内容

我要实现的混合,CompletableFuture.allOf()并且CompletableFuture.anyOf()一旦所有要素都成功完成,返回的未来就成功完成,或者一旦任何要素都异常完成,它就异常地完成(相同的例外)。如果多个元素失败,则返回其中任何一个的异常就足够了。

用例

我有一个任务需要汇总CompletableFutures
列表返回的子结果,但是一旦其中任何一个失败,该任务就应该停止等待。我知道子任务将继续运行,这没关系。

相关问题

我发现在“
等待”列表上等待,最初看起来像是一个重复的问题,但被接受的答案使用CompletionService了要求CallableRunnable作为输入的内容。我正在寻找一个将已经运行的CompletionStages作为输入的解决方案。


问题答案:

这个问题实际上与使用Java 8CompletableFuture替换Futures.successfulAsList十分相似。

尽管问题并不完全相同,但相同的答案(来自我自己)应该可以满足您的需求。

您可以结合使用来实现此功能,allOf()并使用将每个输入的future与链接起来exceptionally(),这样会使allOf()立即返回的future
失败:

CompletableFuture<String> a = …, b = …, c = …;
CompletableFuture<Void> allWithFailFast = CompletableFuture.allOf(a, b, c);
Stream.of(a, b, c)
    .forEach(f -> f.exceptionally(e -> {
        allWithFailFast.completeExceptionally(e);
        return null;
    }));


 类似资料:
  • Java 8的< code > CompletableFuture . allof(CompletableFuture 如果我的一个期货异常完成,那么< code > completablefuture . allof 会在抛出< code>CompletionException之前等待其余期货完成,还是会取消其余期货? 如果它等待所有期货完成,有没有办法让它在任何期货抛出异常并取消剩余期货时立即

  • 现在,我有三个函数:updateFieldFromCollection1()、

  • 我希望通过调用不同的服务来加载应用程序启动时的数据,这些服务返回不同对象类型的列表。每个服务调用DAO类来读取一些数据。因此,我创建了个人如: 并将它们结合起来,如: 如果我这样做: 然后我得到了编译时错误。我不熟悉Java 8的并发特性,例如,我认为调用将在不同的线程中运行每个。调用是否正确?如果是,那么如何删除编译时错误? 但是如果我做了这样的事情: 它正在返回

  • 问: 如何异步处理繁重的业务,避免主业务被长时间阻塞。例如我要给1000用户发送邮件,这个过程很慢,可能要阻塞数秒,这个过程中因为主流程被阻塞,会影响后续的请求,如何将这样的繁重任务交给其它进程异步处理。 答: 可以在本机或者其它服务器甚至服务器集群预先建立一些任务进程处理繁重的业务,任务进程数可以开多一些,例如cpu的10倍,然后调用方利用AsyncTcpConnection将数据异步发送给这些

  • 我有一个可完成期货的列表,我想从第一个期货开始,如果有任何完成例外,我想尝试列表中的下一个期货,依此类推,直到我耗尽了我所有的期货。如果任何一个期货成功了,我想就此止步,而不使用列表中的下一个期货。我如何做到这一点?到目前为止,我已经尝试过: 但是当我测试这种方法时,我看到当未来完成失败时,会抛出异常,并且不会尝试下一组期货。 编辑: 这就是样本的样子

  • 我正在与我无法控制的遗留库集成。 它定义了以下接口: 这个“subscribe”方法被不同的线程频繁调用。我关心“Future.get()”的结果的唯一情况是当它失败时,所以我可以获取并处理异常。这不一定发生在调用线程中。另外,在“Future.get()”上阻塞调用线程对我来说是非常昂贵的,因为即使成功也可能需要几秒钟才能完成。 所以我的任务是以某种方式“后处理”所有这些期货,过滤失败的期货。基