欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java線程之join_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

 更新時(shí)間:2017年05月25日 10:09:15   投稿:mrr  
join() 定義在Thread.java中,下文通過(guò)源碼分享join(),需要的朋友參考下吧

join()介紹

join() 定義在Thread.java中。

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

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

說(shuō)明:

上面的有兩個(gè)類(lèi)Father(主線程類(lèi))和Son(子線程類(lèi))。因?yàn)镾on是在Father中創(chuàng)建并啟動(dòng)的,所以,F(xiàn)ather是主線程類(lèi),Son是子線程類(lèi)。

在Father主線程中,通過(guò)new Son()新建“子線程s”。接著通過(guò)s.start()啟動(dòng)“子線程s”,并且調(diào)用s.join()。在調(diào)用s.join()之后,F(xiàn)ather主線程會(huì)一直等待,直到“子線程s”運(yùn)行完畢;在“子線程s”運(yùn)行完畢之后,F(xiàn)ather主線程才能接著運(yùn)行。 這也就是我們所說(shuō)的“join()的作用,是讓主線程會(huì)等待子線程結(jié)束之后才能繼續(xù)運(yùn)行”! 

 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;
    }
  }
}

說(shuō)明:

從代碼中,我們可以發(fā)現(xiàn)。當(dāng)millis==0時(shí),會(huì)進(jìn)入while(isAlive())循環(huán);即只要子線程是活的,主線程就不停的等待。

我們根據(jù)上面解釋join()作用時(shí)的代碼來(lái)理解join()的用法!

問(wèn)題:

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

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

join()示例

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

// JoinTest.java的源碼
public class JoinTest{ 
  public static void main(String[] args){ 
    try {
      ThreadA t1 = new ThreadA("t1"); // 新建“線程t1”
      t1.start();           // 啟動(dòng)“線程t1”
      t1.join();            // 將“線程t1”加入到“主線程main”中,并且“主線程main()會(huì)等待它的完成”
      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()); 
      // 延時(shí)操作
      for(int i=0; i <1000000; i++)
        ;
      System.out.printf("%s finish\n", this.getName()); 
    } 
  } 
}

運(yùn)行結(jié)果:

t1 start
t1 finish
main finish

結(jié)果說(shuō)明:

運(yùn)行流程如圖

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

(02) 執(zhí)行t1.join()之后,“主線程main”會(huì)進(jìn)入“阻塞狀態(tài)”等待t1運(yùn)行結(jié)束?!白泳€程t1”結(jié)束之后,會(huì)喚醒“主線程main”,“主線程”重新獲取cpu執(zhí)行權(quán),繼續(xù)運(yùn)行。

 以上所述是小編給大家介紹的Java線程之join_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 深入理解Java中的volatile關(guān)鍵字(總結(jié)篇)

    深入理解Java中的volatile關(guān)鍵字(總結(jié)篇)

    volatile這個(gè)關(guān)鍵字,不僅僅在Java語(yǔ)言中有,在很多語(yǔ)言中都有的,而且其用法和語(yǔ)義也都是不盡相同的。這篇文章主要介紹了Java中的volatile關(guān)鍵字,需要的朋友可以參考下
    2018-10-10
  • Mybatis-Plus更新時(shí)間字段不生效的解決

    Mybatis-Plus更新時(shí)間字段不生效的解決

    在使用Mybatis-Plus時(shí),可能會(huì)遇到updateTime字段不自動(dòng)更新的問(wèn)題,通過(guò)分析,原因在于selectById獲取舊數(shù)據(jù)后,如果字段已有值,更新操作不會(huì)自動(dòng)填充更新時(shí)間,可以通過(guò)直接在實(shí)體中設(shè)置更新時(shí)間或在更新操作時(shí)指定時(shí)間來(lái)解決此問(wèn)題
    2024-09-09
  • Java多線程之Interrupt中斷線程詳解

    Java多線程之Interrupt中斷線程詳解

    Interrupt 的其作用是"中斷"線程, 但實(shí)際上線程仍會(huì)繼續(xù)運(yùn)行, 這是一個(gè)非常容易混淆的概念. Interrupt 的真正作用是給線程對(duì)象設(shè)置一個(gè)中斷標(biāo)記, 并不會(huì)影響線程的正常運(yùn)行,需要的朋友可以參考下
    2021-05-05
  • Java字節(jié)碼操縱框架ASM圖文實(shí)例詳解

    Java字節(jié)碼操縱框架ASM圖文實(shí)例詳解

    這篇文章主要為大家介紹了Java字節(jié)碼操縱框架ASM圖文實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • 利用Jackson解決Json序列化和反序列化問(wèn)題

    利用Jackson解決Json序列化和反序列化問(wèn)題

    Jackson是一個(gè)用于處理Json數(shù)據(jù)的Java庫(kù),它提供了一系列功能,包括Json序列化和反序列化,所以本文就來(lái)講講如何利用利用Jackson解決Json序列化和反序列化的問(wèn)題吧
    2023-05-05
  • Java調(diào)用ChatGPT的實(shí)現(xiàn)代碼

    Java調(diào)用ChatGPT的實(shí)現(xiàn)代碼

    這篇文章主要介紹了Java調(diào)用ChatGPT的實(shí)現(xiàn)代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-02-02
  • springboot獲取properties屬性值的多種方式總結(jié)

    springboot獲取properties屬性值的多種方式總結(jié)

    這篇文章主要介紹了springboot獲取properties屬性值的多種方式總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 關(guān)于SpringBoot的熱部署方案

    關(guān)于SpringBoot的熱部署方案

    這篇文章主要介紹了關(guān)于SpringBoot的熱部署方案,每次修改代碼就得將項(xiàng)目重啟,重新部署,對(duì)于一些大型應(yīng)用來(lái)說(shuō),重啟時(shí)間需要花費(fèi)大量的時(shí)間成本,本文就來(lái)詳解熱部署方案,需要的朋友可以參考下
    2023-05-05
  • Java實(shí)現(xiàn)商城訂單超時(shí)取消功能

    Java實(shí)現(xiàn)商城訂單超時(shí)取消功能

    大多數(shù)的B2C商城項(xiàng)目都會(huì)有限時(shí)活動(dòng),當(dāng)用戶(hù)下單后都會(huì)有支付超時(shí)時(shí)間,當(dāng)訂單超時(shí)后訂單的狀態(tài)就會(huì)自動(dòng)變成已取消 ,這個(gè)功能的實(shí)現(xiàn)有很多種方法,本文的實(shí)現(xiàn)方法適合大多數(shù)比較小的商城使用。具體實(shí)現(xiàn)方式可以跟隨小編一起看看吧
    2019-12-12
  • Java多線程中ThreadLocal解讀

    Java多線程中ThreadLocal解讀

    這篇文章主要介紹了Java多線程中ThreadLocal解讀,??多線程訪問(wèn)同一個(gè)共享變量的時(shí)候容易出現(xiàn)并發(fā)問(wèn)題,因此為了保證線程安全性,我們都會(huì)采用加鎖的方式,而ThreadLocal是除加鎖方式之外的另一種保證線程安全性的方法,需要的朋友可以參考下
    2023-09-09

最新評(píng)論