13
を得る:completablefuture参加対CompletableFuture.get()とCompletableFuture.join()の違い</p> <p>以下は私のコードでは何
List<String> process() {
List<String> messages = Arrays.asList("Msg1", "Msg2", "Msg3", "Msg4", "Msg5", "Msg6", "Msg7", "Msg8", "Msg9",
"Msg10", "Msg11", "Msg12");
MessageService messageService = new MessageService();
ExecutorService executor = Executors.newFixedThreadPool(4);
List<String> mapResult = new ArrayList<>();
CompletableFuture<?>[] fanoutRequestList = new CompletableFuture[messages.size()];
int count = 0;
for (String msg : messages) {
CompletableFuture<?> future = CompletableFuture
.supplyAsync(() -> messageService.sendNotification(msg), executor).exceptionally(ex -> "Error")
.thenAccept(mapResult::add);
fanoutRequestList[count++] = future;
}
try {
CompletableFuture.allOf(fanoutRequestList).get();
//CompletableFuture.allOf(fanoutRequestList).join();
} catch (InterruptedException | ExecutionException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return mapResult.stream().filter(s -> !s.equalsIgnoreCase("Error")).collect(Collectors.toList());
}
私は両方の方法を試してみましたが、違いはありませんでは、結果。
ありがとう
'取得()は'あなたを必要としていますので、あなたはtry-catchブロックを必要としないとdisscused
List<String> process
機能を使用する場合代わりに、あなたは完全にを
exceptionally()
方法を利用することができますチェックされた例外をキャッチする。 'get()'から 'join()'に変更したときには、 'InterruptedException'も' ExecutionException'も 'try'ブロックにスローされないというコンパイラエラーが発生するので、違いを気付かなければなりません。 – Holger@ holi-java: 'join()'は中断できません。 – Holger
@Holgerはい、サー。私は仕事を中断することができないことがわかった。 –