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

Java中的notyfy()和notifyAll()的本質(zhì)區(qū)別

 更新時間:2017年02月08日 10:57:21   作者:hao_kkkkk  
很多朋友對java中的notyfy()和notifyAll()的本質(zhì)區(qū)別不了解,今天小編抽空給大家整理一篇教程關(guān)于Java中的notyfy()和notifyAll()的本質(zhì)區(qū)別,需要的朋友參考下吧

wait()方法表示,放棄當(dāng)前對資源的占有權(quán),等啊等啊,一直等到有人通知我,我才會運行后面的代碼。

notify()方法表示,當(dāng)前的線程已經(jīng)放棄對資源的占有,

通知等待的線程來獲得對資源的占有權(quán),但是只有一個線程能夠從wait狀態(tài)中恢復(fù),

然后繼續(xù)運行wait()后面的語句;

notifyAll()方法表示,當(dāng)前的線程已經(jīng)放棄對資源的占有,

通知所有的等待線程從wait()方法后的語句開始運行。

讀出什么區(qū)別沒有?

上例子,先是一個nofiyAll()的例子:

Java代碼

package com.thread.wait; 
public class Wait { 
  private int counter = 0; 
  private String name = null; 
  public Wait(int counter,String name){ 
    this.counter = counter; 
    this.name = name; 
  } 
  public synchronized void doSomthing(){ 
    int tempCounter = --counter; 
    if(tempCounter <= 0){ 
      customizedNotifyAll(); 
    } 
    else 
    { 
      while(tempCounter > 0){ 
        try { 
          System.out.println(Thread.currentThread().getName()+"-<"+name+tempCounter+">"+"will invoke WAIT()"); 
          --tempCounter; 
          wait(); 
        } catch (InterruptedException e) { 
          e.printStackTrace(); 
          notifyAll(); 
        } 
        System.out.println(Thread.currentThread().getName()+"-<"+name+tempCounter+">"+"has been ACTIVED"); 
      } 
      customizedNotifyAll(); 
    } 
  } 
  public void customizedNotifyAll(){ 
    notifyAll(); 
    System.out.println(Thread.currentThread().getName()+"-<"+name+counter+">"+"::"+"INVOKED NOTIFYALL() AND FINISHED"); 
  } 
} 

Java代碼 

package com.thread.wait; 
public class TestThread implements Runnable { 
  private Wait wait; 
  public TestThread(Wait wait){ 
    this.wait = wait; 
  } 
  public void run() { 
    wait.doSomthing(); 
  } 
  public static void main(String [] args){ 
    Wait wait = new Wait(4,"DAVID"); 
    Thread t1 = new Thread(new TestThread(wait)); 
    Thread t2 = new Thread(new TestThread(wait)); 
    Thread t3 = new Thread(new TestThread(wait)); 
    Thread t4 = new Thread(new TestThread(wait)); 
    t1.start(); 
    t2.start(); 
    t3.start(); 
    t4.start(); 
  } 
} 

運行的結(jié)果:

Thread-0-<DAVID3>will invoke WAIT() 
Thread-1-<DAVID2>will invoke WAIT() 
Thread-2-<DAVID1>will invoke WAIT() 
Thread-3-<DAVID0>::INVOKED NOTIFYALL() AND FINISHED 
Thread-0-<DAVID2>has been ACTIVED 
Thread-0-<DAVID2>will invoke WAIT() 
Thread-1-<DAVID1>has been ACTIVED 
Thread-1-<DAVID1>will invoke WAIT() 
Thread-2-<DAVID0>has been ACTIVED 
Thread-2-<DAVID0>::INVOKED NOTIFYALL() AND FINISHED 
Thread-0-<DAVID1>has been ACTIVED 
Thread-0-<DAVID1>will invoke WAIT() 
Thread-1-<DAVID0>has been ACTIVED 
Thread-1-<DAVID0>::INVOKED NOTIFYALL() AND FINISHED 
Thread-0-<DAVID0>has been ACTIVED 
Thread-0-<DAVID0>::INVOKED NOTIFYALL() AND FINISHED 

看到了吧,一旦調(diào)用notifyAll()方法,所有的等待線程都會從調(diào)用wait()方法的地方繼續(xù)運行起來。

這個運行結(jié)果可能每次都不一樣,有時候只有兩個線程運行完成而其余兩個線程在等待其它線程調(diào)用notifyAll()方法,有時候只有三個線程運行完成,而另一個還在等待中。

由于本文是講解notify以及notifyAll方法,所以對上面的原因不多加以解釋。

然后是notify()方法的例子:

就是將wait類中的customizedNotifyAll()方法中的notifyAll()方法換成notify()方法

運行結(jié)果:

Thread-1-<DAVID3>will invoke WAIT() 
Thread-0-<DAVID2>will invoke WAIT() 
Thread-2-<DAVID1>will invoke WAIT() 
Thread-3-<DAVID0>::INVOKED NOTIFYALL() AND FINISHED 
Thread-1-<DAVID2>has been ACTIVED 
Thread-1-<DAVID2>will invoke WAIT() 

Did you see that?所有的等待線程中,只有一個線程運行完成了,而其它的線程還在傻傻地等待,poor guys!

每次運行的結(jié)果會不一樣,但是始終只有一個線程能夠運行完成。

Summary:

notify()方法只是讓一個線程從wait中恢復(fù)過來,至于具體是哪個,那就得看那些線程的運氣了(不設(shè)置優(yōu)先級的情況下),繼續(xù)執(zhí)行后面的語句;

notifyAll()方法是讓所有的線程從wait中恢復(fù)過來,繼續(xù)執(zhí)行后面的語句。

以上所述是小編給大家介紹的Java中的notyfy()和notifyAll()的本質(zhì)區(qū)別,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • java使用list實現(xiàn)數(shù)據(jù)庫的like功能

    java使用list實現(xiàn)數(shù)據(jù)庫的like功能

    這篇文章主要介紹了java使用list實現(xiàn)數(shù)據(jù)庫的like功能,需要的朋友可以參考下
    2014-04-04
  • Java線程中斷機制interrupt、isInterrupted、interrupted方法詳解

    Java線程中斷機制interrupt、isInterrupted、interrupted方法詳解

    這篇文章主要介紹了Java線程中斷機制interrupt、isInterrupted、interrupted方法詳解,一個線程不應(yīng)該由其他線程來強制中斷或停止,而是應(yīng)該由線程自己自行停止,所以,Thread.stop、Thread.suspend、Thread. resume都已經(jīng)被廢棄了,需要的朋友可以參考下
    2024-01-01
  • Java中CyclicBarrier?循環(huán)屏障

    Java中CyclicBarrier?循環(huán)屏障

    這篇文章主要介紹了Java中CyclicBarrier?循環(huán)屏障,可以實現(xiàn)讓一組線程等待至某個狀態(tài)屏障點之后再全部同時執(zhí)行,下面文章分享CyclicBarrier循環(huán)屏障的原理,需要的小伙伴可以參考一下
    2022-05-05
  • java實現(xiàn)的導(dǎo)出Excel工具類實例

    java實現(xiàn)的導(dǎo)出Excel工具類實例

    這篇文章主要介紹了java實現(xiàn)的導(dǎo)出Excel工具類,結(jié)合具體實例形式分析了java導(dǎo)出Excel導(dǎo)出并生成Excel表格相關(guān)操作技巧與注意事項,需要的朋友可以參考下
    2017-10-10
  • Java異常處理實例詳解

    Java異常處理實例詳解

    這篇文章主要介紹了Java異常處理實例詳解,列舉了實際例子講解的很清晰,有感興趣的同學(xué)可以學(xué)習(xí)下
    2021-03-03
  • Spring Cloud Hystrix 服務(wù)容錯保護的原理實現(xiàn)

    Spring Cloud Hystrix 服務(wù)容錯保護的原理實現(xiàn)

    這篇文章主要介紹了Spring Cloud Hystrix 服務(wù)容錯保護的原理實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • springboot中RestTemplate發(fā)送HTTP請求的實現(xiàn)示例

    springboot中RestTemplate發(fā)送HTTP請求的實現(xiàn)示例

    RestTemplate是一個 spring-web 提供的執(zhí)行HTTP請求的同步阻塞式工具類,本文就來介紹一下RestTemplate發(fā)送HTTP請求,具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • 一篇文章告訴你JAVA Mybatis框架的核心原理到底有多重要

    一篇文章告訴你JAVA Mybatis框架的核心原理到底有多重要

    yBatis的底層操作封裝了JDBC的API,MyBatis的工作原理以及核心流程與JDBC的使用步驟一脈相承,MyBatis的核心對象(SqlSession,Executor)與JDBC的核心對象(Connection,Statement)相互對應(yīng)
    2021-06-06
  • 使用RestTemplate調(diào)用RESTful?API的代碼示例

    使用RestTemplate調(diào)用RESTful?API的代碼示例

    在開發(fā)?Web?應(yīng)用程序時,調(diào)用?RESTful?API?是一個常見的任務(wù),本文將介紹如何使用?RestTemplate?調(diào)用?RESTful?API,并提供示例代碼,感興趣的同學(xué)可以跟著小編一起來看看
    2023-06-06
  • Java連接Vmware中的redis

    Java連接Vmware中的redis

    這篇文章主要為大家介紹了Java連接Vmware中的redis
    2016-01-01

最新評論