首页 > 解决方案 > 有没有办法延迟可完成未来的执行?

问题描述

我将使用 CompletableFuture 进行异步调用。我想知道是否有办法延迟其执行。对于一个流程,我有大约 5 个异步调用,然后我根据需要链接然后使用 thenApply/thenCompose。我的问题是当我为调用创建第一个 CF 时,只要线程空闲,它就会开始执行。我希望首先我的所有任务都应该被链接起来,然后当我调用完成()时,它开始执行。我正在寻找的是类似于 Java 流中的中间操作的东西。在我之前关于 SO 的一个问题中,我对此有一些帮助,但这并没有解决我的目的。

我的技术栈只支持 Java 8,所以不能使用下一个版本中推出的任何功能。

标签: javaasynchronousjava-streamcompletable-future

解决方案


我还不能写评论,所以我不能要求澄清。请原谅我,如果我没有正确理解,你需要什么。据我所知,您基本上只是在寻找一种方法来延迟 CompletableFuture 的执行,直到您准备好这样做。

您是否考虑过为要调用的函数提供另一个 CF 作为参数?准备好后,只需完成此 CF 即可执行该函数。它有点像这样:

CompletableFuture<Void> setup = new CompletableFuture<>();
delayedFunction(setup);

//do whatever you want
System.out.println("foo");

//once you are ready, complete setup to execute the delayed function
setup.complete(null);


public static CompletableFuture<Void> delayedFunction(CompletableFuture<Void> setup) {
  return setup.
    thenAccept(v-> {
      System.out.println("bar");
    });
}

推荐阅读