thenApplye thenComposesão métodos de CompletableFuture. Use-os quando quiser fazer algo para obter CompleteableFutureo resultado de a Function.
thenApplye thenComposeambos retornam a CompletableFuturecomo seu próprio resultado. Você pode encadear vários thenApplyou thenComposejuntos. Forneça um Functionpara cada chamada, cujo resultado será a entrada para a próxima Function.
O que Functionvocê forneceu às vezes precisa fazer algo de forma síncrona. O tipo de retorno de seu Functiondeve ser um não Futuretipo. Neste caso, você deve usar thenApply.
CompletableFuture.completedFuture(1)
.thenApply((x)->x+1) // adding one to the result synchronously, returns int
.thenApply((y)->System.println(y)); // value of y is 1 + 1 = 2
Outras vezes, você pode querer fazer processamento assíncrono neste Function. Nesse caso, você deve usar thenCompose. O tipo de retorno de seu Functiondeve ser a CompletionStage. O próximo Functionna cadeia obterá o resultado disso CompletionStagecomo entrada, desembrulhando o CompletionStage.
// addOneAsync may be implemented by using another thread, or calling a remote method
abstract CompletableFuture<Integer> addOneAsync(int input);
CompletableFuture.completedFuture(1)
.thenCompose((x)->addOneAsync(x)) // doing something asynchronous, returns CompletableFuture<Integer>
.thenApply((y)->System.println(y)); // y is an Integer, the result of CompletableFuture<Integer> above
Esta é uma ideia semelhante à do Javascript Promise. Promise.thenpode aceitar uma função que retorna um valor ou Promisede um valor. A razão pela qual esses dois métodos têm nomes diferentes em Java é devido ao apagamento genérico . Function<? super T,? extends U> fne Function<? super T,? extends CompletionStage<U>> fnsão considerados o mesmo tipo de tempo de execução - Function. Portanto, thenApplye thenComposedeve ser nomeado de forma distinta, ou o compilador Java reclamaria sobre assinaturas de método idênticas. O resultado final é que o Javascript Promise.thené implementado em duas partes - thenApplye thenCompose- em Java.
Você pode ler minha outra resposta se também estiver confuso sobre uma função relacionada thenApplyAsync.
mapeflatMapemStream?thenApplyé omapethenComposeé oflatMapdeCompletableFuture. Você usathenComposepara evitar terCompletableFuture<CompletableFuture<..>>.