completablefuture.join方法
时间: 2023-11-24 14:50:24 浏览: 257
Stream流式计算、ForkJoin和异步回调.md
`CompletableFuture.join()` 方法是一个阻塞方法,它会等待 `CompletableFuture` 的计算完成并返回结果。如果 `CompletableFuture` 的计算已经完成,它会立即返回结果,否则它会一直阻塞直到计算完成。
以下是一个使用 `CompletableFuture.join()` 方法的例子:
```java
CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> {
// 模拟一个长时间的计算
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return "Hello";
});
String result = future.join(); // 阻塞等待计算完成并返回结果
System.out.println(result); // 输出:Hello
```
在上面的例子中,我们使用 `CompletableFuture.supplyAsync()` 方法创建了一个异步计算任务,并返回一个 `CompletableFuture` 对象。然后我们调用 `join()` 方法等待计算完成并返回结果。
阅读全文