91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java線程之join_動力節點Java學院整理

發布時間:2020-10-04 00:41:24 來源:腳本之家 閱讀:152 作者:mrr 欄目:編程語言

join()介紹

join() 定義在Thread.java中。

join() 的作用:讓“主線程”等待“子線程”結束之后才能繼續運行。這句話可能有點晦澀,我們還是通過例子去理解: 

// 主線程
public class Father extends Thread {
  public void run() {
    Son s = new Son();
    s.start();
    s.join();
    ...
  }
}
// 子線程
public class Son extends Thread {
  public void run() {
    ...
  }
}

說明:

上面的有兩個類Father(主線程類)和Son(子線程類)。因為Son是在Father中創建并啟動的,所以,Father是主線程類,Son是子線程類。

在Father主線程中,通過new Son()新建“子線程s”。接著通過s.start()啟動“子線程s”,并且調用s.join()。在調用s.join()之后,Father主線程會一直等待,直到“子線程s”運行完畢;在“子線程s”運行完畢之后,Father主線程才能接著運行。 這也就是我們所說的“join()的作用,是讓主線程會等待子線程結束之后才能繼續運行”! 

 join()源碼分析(基于JDK1.7.0_40) 

public final void join() throws InterruptedException {
  join(0);
}
public final synchronized void join(long millis)
throws InterruptedException {
  long base = System.currentTimeMillis();
  long now = 0;
  if (millis < 0) {
    throw new IllegalArgumentException("timeout value is negative");
  }
  if (millis == 0) {
    while (isAlive()) {
      wait(0);
    }
  } else {
    while (isAlive()) {
      long delay = millis - now;
      if (delay <= 0) {
        break;
      }
      wait(delay);
      now = System.currentTimeMillis() - base;
    }
  }
}

說明:

從代碼中,我們可以發現。當millis==0時,會進入while(isAlive())循環;即只要子線程是活的,主線程就不停的等待。

我們根據上面解釋join()作用時的代碼來理解join()的用法!

問題:

雖然s.join()被調用的地方是發生在“Father主線程”中,但是s.join()是通過“子線程s”去調用的join()。那么,join()方法中的isAlive()應該是判斷“子線程s”是不是Alive狀態;對應的wait(0)也應該是“讓子線程s”等待才對。但如果是這樣的話,s.join()的作用怎么可能是“讓主線程等待,直到子線程s完成為止”呢,應該是讓"子線程等待才對(因為調用子線程對象s的wait方法嘛)"?

答案:wait()的作用是讓“當前線程”等待,而這里的“當前線程”是指當前在CPU上運行的線程。所以,雖然是調用子線程的wait()方法,但是它是通過“主線程”去調用的;所以,休眠的是主線程,而不是“子線程”! 

join()示例

在理解join()的作用之后,接下來通過示例查看join()的用法。 

// JoinTest.java的源碼
public class JoinTest{ 
  public static void main(String[] args){ 
    try {
      ThreadA t1 = new ThreadA("t1"); // 新建“線程t1”
      t1.start();           // 啟動“線程t1”
      t1.join();            // 將“線程t1”加入到“主線程main”中,并且“主線程main()會等待它的完成”
      System.out.printf("%s finish\n", Thread.currentThread().getName()); 
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
  } 
  static class ThreadA extends Thread{
    public ThreadA(String name){ 
      super(name); 
    } 
    public void run(){ 
      System.out.printf("%s start\n", this.getName()); 
      // 延時操作
      for(int i=0; i <1000000; i++)
        ;
      System.out.printf("%s finish\n", this.getName()); 
    } 
  } 
}

運行結果:

t1 start
t1 finish
main finish

結果說明:

運行流程如圖

(01) 在“主線程main”中通過 new ThreadA("t1") 新建“線程t1”。 接著,通過 t1.start() 啟動“線程t1”,并執行t1.join()。

(02) 執行t1.join()之后,“主線程main”會進入“阻塞狀態”等待t1運行結束。“子線程t1”結束之后,會喚醒“主線程main”,“主線程”重新獲取cpu執行權,繼續運行。

Java線程之join_動力節點Java學院整理

 以上所述是小編給大家介紹的Java線程之join_動力節點Java學院整理,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

咸宁市| 和硕县| 永川市| 五台县| 翼城县| 高要市| 海淀区| 许昌县| 南江县| 万全县| 建德市| 古丈县| 眉山市| 宽甸| 晋城| 承德县| 白朗县| 五寨县| 布尔津县| 沙田区| 清新县| 宁明县| 绥宁县| 石门县| 安图县| 汽车| 平利县| 兴国县| 民和| 承德市| 宜宾县| 潞城市| 婺源县| 庄浪县| 乌兰察布市| 志丹县| 邹城市| 思南县| 无极县| 锡林郭勒盟| 岳池县|