栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java object wait notify notifyAll代码解析

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java object wait notify notifyAll代码解析

测试代码:

public static Object loc=new Object();

  public static void main(String[] args) throws Exception{

    Thread t1=new Thread(new Runnable() {
      @Override
      public void run() {
 try {
   java.text.SimpleDateFormat sdf=new SimpleDateFormat("HH:mm:ss SSS");
   System.out.println("["+sdf.format(new Date())+"] t1___等待锁...");
   synchronized (loc) {
     System.out.println("["+sdf.format(new Date())+"] t1___获得锁 ...");
     Thread.sleep(5000);
     System.out.println("["+sdf.format(new Date())+"] t1___loc..开始执行wait...");
     loc.wait();
     System.out.println("["+sdf.format(new Date())+"] t1___loc..执行wait后续...");
     Thread.sleep(1000);
   }
   System.out.println("["+sdf.format(new Date())+"] t1___loc..离开锁...");
 }catch (Exception e){
   e.printStackTrace();
 }
      }
    });
    Thread t3=new Thread(new Runnable() {
      @Override
      public void run() {
 try {
   java.text.SimpleDateFormat sdf=new SimpleDateFormat("HH:mm:ss SSS");
   System.out.println("["+sdf.format(new Date())+"] t3___等待锁...");
   synchronized (loc) {
     System.out.println("["+sdf.format(new Date())+"] t3___进入锁...");
     Thread.sleep(5000);
     System.out.println("["+sdf.format(new Date())+"] t3___loc..开始 wait...");
     loc.wait();
     System.out.println("["+sdf.format(new Date())+"] t3___loc..执行 wait后续...");
     Thread.sleep(1000);
   }
   System.out.println("["+sdf.format(new Date())+"] t3___离开锁...");
 }catch (Exception e){
   e.printStackTrace();
 }
      }
    });

    Thread t2=new Thread(new Runnable() {
      @Override
      public void run() {
 try {
   java.text.SimpleDateFormat sdf=new SimpleDateFormat("HH:mm:ss SSS");
   System.out.println("["+sdf.format(new Date())+"] t2___等待锁...");
   synchronized (loc) {
     System.out.println("["+sdf.format(new Date())+"] t2___获得锁...");
     Thread.sleep(5000);
     System.out.println("["+sdf.format(new Date())+"] t2___loc..开始执行 notify...");
     loc.notify();
     System.out.println("["+sdf.format(new Date())+"] t2___loc..执行 notify后续...");
     Thread.sleep(1000);
   }
   System.out.println("["+sdf.format(new Date())+"] t2___loc 离开锁....");
 }catch (Exception e){
   e.printStackTrace();
 }
      }
    });
    t1.start();
    t3.start();
    Thread.sleep(500);
    t2.start();


    System.out.println("t1___before join ....");
    t1.join();
    System.out.println("t2___before join ....");
    t2.join();
    System.out.println("t3____before join ....");
    t3.join();
    System.out.println("main exit....");
  }

执行结果:

[16:55:59 384] t1___等待锁...

[16:55:59 384] t1___获得锁 ...

[16:55:59 384] t3___等待锁...
t1___before join ....
[16:55:59 836] t2___等待锁...
[16:56:04 392] t1___loc..开始执行wait...

[16:56:04 392] t2___获得锁...
[16:56:09 392] t2___loc..开始执行 notify...
[16:56:09 392] t2___loc..执行 notify后续...
[16:56:10 392] t2___loc 离开锁....


[16:56:10 392] t3___进入锁...
[16:56:15 392] t3___loc..开始 wait...
[16:56:15 392] t1___loc..执行wait后续...
[16:56:16 392] t1___loc..离开锁...
t2___before join ....
t3____before join ....

总结:

1. 执行wait后‘'暂时‘ 释放当前对象锁给其他线程,当前线程处于等待状态

2. syn块中的wait收到notify通知后 唤醒cpu 继续判断锁状态

3. 执行notify且当前的对象锁释放后 wait等待的线程激活

4. notifyAll 是一次唤醒所有的wait

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/130434.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号