淺談Java多線程中的join方法,淺談java多線程join

來源:互聯網
上載者:User

淺談Java多線程中的join方法,淺談java多線程join

先上代碼

建立一個Thread,代碼如下:

 1 package com.thread.test; 2  3 public class MyThread extends Thread { 4     private String name; 5     public MyThread(String name) { 6         this.name = name; 7     } 8     @Override 9     public void run() {10         for (int i = 0; i < 100; i++) {11             System.out.println(name+"["+i+"]");12         }13         super.run();14     }15 }

之後建立測試類別,代碼如下:

package com.thread.test;/* * 0-50執行的是主線程,50-100執行的是A線程,並且將A線程完全執行完後才繼續執行主線程 */public class ThreadDemo{    public static void main(String[] args) {        MyThread t = new MyThread("A");        t.start();        for (int i = 0; i < 100; i++) {            if (i>50) {                try {                    t.join();                } catch (InterruptedException e) {                    e.printStackTrace();                }            }            System.out.println("主線程"+"["+i+"]");        }    }}

下面是Java Platform SE8 API中對Thread中Join方法的解釋:

public final void join(long millis)                throws InterruptedExceptionWaits at most millis milliseconds for this thread to die. A timeout of 0 means to wait forever. This implementation uses a loop of this.wait calls conditioned on this.isAlive. As a thread terminates the this.notifyAll method is invoked. It is recommended that applications not use wait, notify, or notifyAll on Thread instances.Parameters: millis - the time to wait in milliseconds Throws: IllegalArgumentException - if the value of millis is negative InterruptedException - if any thread has interrupted the current thread. The interrupted status of the current thread is cleared when this exception is thrown.

先上代碼

建立一個Thread,代碼如下:

 1 package com.thread.test; 2  3 public class MyThread extends Thread { 4     private String name; 5     public MyThread(String name) { 6         this.name = name; 7     } 8     @Override 9     public void run() {10         for (int i = 0; i < 100; i++) {11             System.out.println(name+"["+i+"]");12         }13         super.run();14     }15 }

之後建立測試類別,代碼如下:

package com.thread.test;/* * 0-50執行的是主線程,50-100執行的是A線程,並且將A線程完全執行完後才繼續執行主線程 */public class ThreadDemo{    public static void main(String[] args) {        MyThread t = new MyThread("A");        t.start();        for (int i = 0; i < 100; i++) {            if (i>50) {                try {                    t.join();                } catch (InterruptedException e) {                    e.printStackTrace();                }            }            System.out.println("主線程"+"["+i+"]");        }    }}

下面是Java Platform SE8 API中對Thread中Join方法的解釋:

public final void join(long millis)                throws InterruptedExceptionWaits at most millis milliseconds for this thread to die. A timeout of 0 means to wait forever. This implementation uses a loop of this.wait calls conditioned on this.isAlive. As a thread terminates the this.notifyAll method is invoked. It is recommended that applications not use wait, notify, or notifyAll on Thread instances.Parameters: millis - the time to wait in milliseconds Throws: IllegalArgumentException - if the value of millis is negative InterruptedException - if any thread has interrupted the current thread. The interrupted status of the current thread is cleared when this exception is thrown.

 我自己的理解就是會強行進入使用join方法的線程,其他線程等待該線程完全執行完後才會進來。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.