Vin*_*air 5 java parallel-processing nonblocking chaining completable-future
我的应用程序中有 3 种不同的方法。都回来了CompletableFuture<SomeType>。我想并行执行方法 1 和方法 2。完成方法 1 和方法 2 后,我想使用方法 1 和方法 2 返回值的参数触发方法 3。
代码示例:
CompletableFuture<Request> future1 = RequestConverter.Convert(requestDto);
CompletableFuture<String> future2 = tokenProvider.getAuthToken();
CompletableFuture<CompletableFuture<String>> future3 =
future1.thenCombine(future2,(request,token) ->
requestProcessor.Process(request,token));
Run Code Online (Sandbox Code Playgroud)
但是,与上面的代码的问题是,我得到一个CompletableFuture的CompletableFuture。我想避免这种情况并获得简单CompletableFuture<String>而不阻塞。这可能吗?
由于没有组合 thenCombine()and的方法thenCompose(),您可以使用thenCompose()来解开CompletableFuture来自您的嵌套thenCombine():
CompletableFuture<CompletableFuture<String>> future3 =
future1.thenCombine(future2, (request,token) ->
requestProcessor.Process(request,token));
CompletableFuture<String> future4 = future3.thenCompose(c -> c);
Run Code Online (Sandbox Code Playgroud)
假设你有这Pair门课。
class Pair<L, R> {
public final L left;
public final R right;
public Pair(L left, R right) {
this.left = left;
this.right = right;
}
}
Run Code Online (Sandbox Code Playgroud)
然后你可以先组合成一对然后组合。
CompletableFuture<Request> future1 = RequestConverter.Convert(requestDto);
CompletableFuture<String> future2 = tokenProvider.getAuthToken();
CompletableFuture<String> future3 = future1
.thenCombine(future2, Pair::new)
.thenCompose(pair -> requestProcessor.Process(pair.left, pair.right));
Run Code Online (Sandbox Code Playgroud)