Sef*_*ffy 4 java java-8 completable-future
我使用以下工作代码CompleteableFuture
:
CompletableFuture<SomeObject> future = CompletableFuture.
supplyAsync( () -> f1() ).
thenApplyAsync( f1Output -> f2( f1Output ) ).
thenApplyAsync( f2Output -> f3( f2Output ) );
Run Code Online (Sandbox Code Playgroud)
是否有可能运行另一个接收f1Output
类似以下内容的未来input?
:
CompletableFuture<SomeObject> future = CompletableFuture.
supplyAsync( () -> f1() ).
thenApplyAsync( f1Output -> f2( f1Output ) ).
someApiThatRuns( f1Output -> f4( f1Output ) ). // <--
thenApplyAsync( f2Output -> f3( f2Output ) );
Run Code Online (Sandbox Code Playgroud)
如果这简化了事情,人们可以忽略 . 返回的结果f4()
。
如果您不介意按顺序运行f2
和f4
运行,最简单的方法就是在 lambda 中调用两者:
CompletableFuture<SomeObject> future = CompletableFuture.
supplyAsync(() -> f1() ).
thenApplyAsync(f1Output -> { f4(f1Output); return f2(f1Output); } ).
thenApplyAsync(f2Output -> f3(f2Output));
Run Code Online (Sandbox Code Playgroud)
但是,如果您想f2
并行运行f4
,您可以将中间未来存储在变量中:
CompletableFuture<SomeObject> f1Future = CompletableFuture.supplyAsync(() -> f1());
CompletableFuture<SomeObject> future = f1Future.
thenApplyAsync(f1Output -> f2(f1Output)).
thenApplyAsync(f2Output -> f3(f2Output));
f1Future.thenAcceptAsync(f1Output -> f4(f1Output));
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
1671 次 |
最近记录: |