初めて質問するのでおかしいところがあれば申し訳ないです。
Javaを勉強中なのですが、以下のコードのスレッドが
どんな順序で実行されているのかイメージがつかめなかったので質問させて頂きました。
Java
1//Threadクラスを継承したクラス 2public class ThreadTest extends Thread{ 3 private String str; 4 private int time; 5 private int count; 6 7 //コンストラクタ 8 public ThreadTest(String str, int time, int count){ 9 this.str = str; 10 this.time = time; 11 this.count = count; 12 } 13 //run()メソッドをオーバーライド 14 public void run(){ 15 //指定した回数分(count)を繰り返す 16 for(int i = 0; i < count; i++){ 17 System.out.print(str); 18 19 try{ 20 //指定した時間(time)の間スレッドを停止 21 sleep(time); 22 //例外処理 23 } catch (Exception e){ 24 System.out.println("例外が発生しました。"); 25 } 26 } 27 } 28 29 public static void main(String[] args){ 30 //コンストラクタで各スレッドの文字列、停止時間、回数を設定 31 ThreadTest a = new ThreadTest("ABC", 2000, 4); 32 ThreadTest b = new ThreadTest("あいう\r\n", 2000, 3); 33 34 //aのスレッドを実行 35 a.start(); 36 try{ 37 //スレッドを500ミリ秒停止 38 sleep(500); 39 } catch (Exception e){ 40 41 } 42 //bのスレッドを実行 43 b.start(); 44 } 45} 46
結果としては以下のようになります。(カッコの秒数は停止時間)
ABC(0.5秒停止)あいう(2秒停止)
ABC(0.5秒停止)あいう(2秒停止)
ABC(0.5秒停止)あいう(2秒停止)
ABC
流れとしては下記の順になるのではと考えましたが、どこか間違えているような気がするので間違いや補足があればご指摘頂けますでしょうか。
1.スレッドaが開始
2.スレッドa500ミリ秒(0.5秒)一時停止
3.スレッドbが開始
4.スレッドaとスレッドbが2000ミリ秒(2秒)停止
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/04/04 13:00