質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

Q&A

解決済

2回答

1048閲覧

CompletableFuture.allOf(a, b, c).join(); がある場合と無い場合の動作結果の違いを生じさせたい。

yuzunoha123

総合スコア28

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

0グッド

0クリップ

投稿2023/03/30 07:32

編集2023/03/30 09:12

前提

オラクルのページの下記の記述が再現できなくて困っています。
https://docs.oracle.com/javase/jp/8/docs/api/java/util/concurrent/CompletableFuture.html

このメソッドの用途の1つは、CompletableFuture.allOf(c1, c2, c3).join();のように、プログラムを続行する前に一連の独立したCompletableFutureの完了を待機することです。

問題・課題

  • 下記のメソッド allOfOff() において、なぜ CompletableFuture.allOf(a, b, c).join(); が無い場合でも一番時間のかかるbの表示が最後にならないのでしょうか。
  • CompletableFuture.allOf(a, b, c).join(); がある場合と無い場合の動作結果の違いを生じさせることは可能でしょうか。

該当のソースコード

Java

1import java.util.concurrent.CompletableFuture; 2import java.util.function.Supplier; 3 4public class Main { 5 public static void main(String[] args) throws Exception { 6 allOfOn(); 7 allOfOff(); 8 } 9 10 private static Supplier<String> createSupplier(String s, long ms) { 11 return () -> { 12 try { 13 Thread.sleep(ms); 14 } catch (InterruptedException e) { 15 e.printStackTrace(); 16 } 17 return s; 18 }; 19 } 20 21 private static void allOfOn() { 22 long startMs = System.currentTimeMillis(); 23 24 var a = CompletableFuture.supplyAsync(createSupplier("aです。", 100)); 25 var b = CompletableFuture.supplyAsync(createSupplier("bです。", 200)); 26 var c = CompletableFuture.supplyAsync(createSupplier("cです。", 150)); 27 28 // これがあってもなくても同じなのが不思議 29 CompletableFuture.allOf(a, b, c).join(); 30 31 System.out.println(a.join()); 32 System.out.println(b.join()); 33 System.out.println(c.join()); 34 35 var lapseMs = System.currentTimeMillis() - startMs; 36 System.out.println(lapseMs + "ミリ秒"); 37 } 38 39 private static void allOfOff() { 40 long startMs = System.currentTimeMillis(); 41 42 var a = CompletableFuture.supplyAsync(createSupplier("aです。", 100)); 43 var b = CompletableFuture.supplyAsync(createSupplier("bです。", 200)); 44 var c = CompletableFuture.supplyAsync(createSupplier("cです。", 150)); 45 46 // これがあってもなくても同じなのが不思議 47 // CompletableFuture.allOf(a, b, c).join(); 48 49 System.out.println(a.join()); 50 System.out.println(b.join()); 51 System.out.println(c.join()); 52 53 var lapseMs = System.currentTimeMillis() - startMs; 54 System.out.println(lapseMs + "ミリ秒"); 55 } 56}

該当のソースコードの実行結果

bash

1aです。 2bです。 3cです。 4200ミリ秒 5aです。 6bです。 7cです。 8201ミリ秒

補足情報(FW/ツールのバージョンなど)

動作環境

手元のJavaとpaiza.ioにて当該の挙動を確認しています。
https://paiza.io/projects/cvHXvQv0qM4pLd7falyxeg

手元のJavaのバージョン

bash-4.2# javac -version
javac 11.0.18

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

Java

1 private static Supplier<String> createSupplier(String s, long ms) { 2 return () -> { 3 try { 4 Thread.sleep(ms); 5 } catch (InterruptedException e) { 6 e.printStackTrace(); 7 } 8 System.out.println("------" + s); // ←コレ追加 9 return s; 10 }; 11 }

実行結果

------aです。 ------cです。 ------bです。//*** a,b,c全部完了するまで待ってくれてる aです。 bです。 cです。 222ミリ秒 ------aです。 aです。// ***完了を待たずに動き始めた ------cです。 ------bです。 bです。 cです。 201ミリ秒

投稿2023/03/31 04:25

episteme

総合スコア16614

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yuzunoha123

2023/04/03 07:08

ありがとうございます!!!
guest

0

a, b, c がどの順番で終わろうが、 a, b, c の順に表示しているのですから、そうならないほうがおかしいでしょう。

動作結果の違いを生じさせる

allOf を含む各 join の前後で時間でも出してみては如何でしょうか。

投稿2023/03/30 10:01

編集2023/03/30 13:26
jimbe

総合スコア12646

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問