Java 8 - 并行调用异步方法并合并它们的结果

标签 java asynchronous java-8

我是 Java 8 并发特性(例如 CompletableFuture)的新手,希望您能帮助我开始使用以下用例。

有一个名为 TimeConsumingServices 的服务,它提供耗时的操作,我想并行运行这些操作,因为它们都是独立的。

interface TimeConsumingService {

  default String hello(String name) {
    System.out.println(System.currentTimeMillis() + " > hello " + name);
    return "Hello " + name;
  }
  default String planet(String name) {
    System.out.println(System.currentTimeMillis() + " > planet " + name);
    return "Planet: " + name;
  }
  default String echo(String name) {
    System.out.println(System.currentTimeMillis() + " > echo " + name);
    return name;
  }

  default byte[] convert(String hello, String planet, String echo) {
    StringBuilder sb = new StringBuilder();
    sb.append(hello);
    sb.append(planet);
    sb.append(echo);
    return sb.toString().getBytes();
  }
}

到目前为止,我实现了以下示例,并且成功地并行调用了所有三个服务方法。

public class Runner implements TimeConsumingService {

  public static void main(String[] args) {
    new Runner().doStuffAsync();
  }

  public void doStuffAsync() {
    CompletableFuture<String> future1 = CompletableFuture.supplyAsync(() -> this.hello("Friend"));
    CompletableFuture<String> future2 = CompletableFuture.supplyAsync(() -> this.planet("Earth"));
    CompletableFuture<String> future3 = CompletableFuture.supplyAsync(() -> this.echo("Where is my echo?"));

    CompletableFuture.allOf(future1, future2, future3).join();
  }
}

有没有办法收集每个服务调用的返回值并调用byte[]‘convert(String, String, String)方法?

最佳答案

要在返回所有结果后合并结果,您可以这样做

CompletableFuture<byte[]> byteFuture = CompletableFuture.allOf(cf1, cf2, cf3)
                     .thenApplyAsync(aVoid -> convert(cf1.join(), cf2.join(), cf3.join()));
byte[] bytes = byteFuture.join();

这将运行您所有的 future ,等待它们全部完成,然后在它们全部完成后立即调用您提到的 convert 方法。

关于Java 8 - 并行调用异步方法并合并它们的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42504277/

相关文章:

Java jersey 导入包

java - JASPIC JDBC 领域身份验证的 "register new user"解决方案是什么?

scala - Future.onComplete : can't understand the method signature

javascript - 处理需要彼此数据的嵌套异步函数的最佳方法是什么?

java - 使用 lambda 进行代码重构 - Java 8

java - 从文件中分割字符串换行符

java - 如何在 Android 中以最佳方式调整位图大小?

javascript - 异步代码执行解释

java - Int 流和收集

java - 使用 java 8 流基于另一个 List<Object2> 填充 List<Object1>