notify() 和 notifyAll() 有什么区别?「建议收藏」

notify() 和 notifyAll() 有什么区别?「建议收藏」notify()和notifyAll()有什么区别?先解释两个概念。等待池:假设一个线程A调用了某个对象的wait()方法,线程A就会释放该对象的锁后,进入到了该对象的等待池,等待池中的线程不会去竞争该对象的锁。 锁池:只有获取了对象的锁,线程才能执行对象的synchronized代码,对象的锁每次只有一个线程可以获得,其他线程只能在锁池中等待区别:notify()…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

notify() 和 notifyAll() 有什么区别?

先解释两个概念。

  • 等待池:假设一个线程A调用了某个对象的wait()方法,线程A就会释放该对象的锁后,进入到了该对象的等待池,等待池中的线程不会去竞争该对象的锁。
  • 锁池:只有获取了对象的锁,线程才能执行对象的 synchronized 代码,对象的锁每次只有一个线程可以获得,其他线程只能在锁池中等待

区别:

notify() 方法随机唤醒对象的等待池中的一个线程,进入锁池;notifyAll() 唤醒对象的等待池中的所有线程,进入锁池。

测试代码

public class TestNotifyNotifyAll {

	private static Object obj = new Object();
	
	public static void main(String[] args) {
		
		//测试 RunnableImplA wait()        
		Thread t1 = new Thread(new RunnableImplA(obj));
		Thread t2 = new Thread(new RunnableImplA(obj));
		t1.start();
		t2.start();
		
		//RunnableImplB notify()
		Thread t3 = new Thread(new RunnableImplB(obj));
		t3.start();
		
		
//		//RunnableImplC notifyAll()
//		Thread t4 = new Thread(new RunnableImplC(obj));
//		t4.start();
	}
	
}


class RunnableImplA implements Runnable {

	private Object obj;
	
	public RunnableImplA(Object obj) {
		this.obj = obj;
	}
	
	public void run() {
		System.out.println("run on RunnableImplA");
		synchronized (obj) {
			System.out.println("obj to wait on RunnableImplA");
			try {
				obj.wait();
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
			System.out.println("obj continue to run on RunnableImplA");
		}
	}
}

class RunnableImplB implements Runnable {

	private Object obj;
	
	public RunnableImplB(Object obj) {
		this.obj = obj;
	}
	
	public void run() {
		System.out.println("run on RunnableImplB");
		System.out.println("睡眠3秒...");
		try {
			Thread.sleep(3000);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		synchronized (obj) {
			System.out.println("notify obj on RunnableImplB");
			obj.notify();
		}
	}
}

class RunnableImplC implements Runnable {

	private Object obj;
	
	public RunnableImplC(Object obj) {
		this.obj = obj;
	}
	
	public void run() {
		System.out.println("run on RunnableImplC");
		System.out.println("睡眠3秒...");
		try {
			Thread.sleep(3000);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		synchronized (obj) {
			System.out.println("notifyAll obj on RunnableImplC");
			obj.notifyAll();
		}
	}
}

结果:仅调用一次 obj.notify(),线程 t1 或 t2 中的一个始终在等待被唤醒,程序不终止

run on RunnableImplA
obj to wait on RunnableImplA
run on RunnableImplA
obj to wait on RunnableImplA
run on RunnableImplB
睡眠3秒...
notify obj on RunnableImplB
obj continue to run on RunnableImplA

 把 t3 注掉,启动 t4 线程。调用 obj.notifyAll() 方法

public class TestNotifyNotifyAll {

	private static Object obj = new Object();
	
	public static void main(String[] args) {
		
		//测试 RunnableImplA wait()        
		Thread t1 = new Thread(new RunnableImplA(obj));
		Thread t2 = new Thread(new RunnableImplA(obj));
		t1.start();
		t2.start();
		
//		//RunnableImplB notify()
//		Thread t3 = new Thread(new RunnableImplB(obj));
//		t3.start();
		
		
		//RunnableImplC notifyAll()
		Thread t4 = new Thread(new RunnableImplC(obj));
		t4.start();
	}
	
}

 

 结果:t1、t2线程均可以执行完毕

run on RunnableImplA
obj to wait on RunnableImplA
run on RunnableImplA
obj to wait on RunnableImplA
run on RunnableImplC
睡眠3秒...
notifyAll obj on RunnableImplC
obj continue to run on RunnableImplA
obj continue to run on RunnableImplA

 


【Java面试题与答案】整理推荐

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/195903.html原文链接:https://javaforall.net

(0)
上一篇 2025年10月8日 上午9:22
下一篇 2025年10月8日 上午10:01


相关推荐

  • 浅析 Comparable和 Comparator的区别

    浅析 Comparable和 Comparator的区别简介 Comparable 和 Comparator 都是 java util 包下的两个接口 从字面上看这两个接口都是用来做比较用的 但是 jdk 里面不可能定义两个功能相同的接口 所以他们肯定有不同的用处 1 Comparable1 1 说明 Comparable 可以认为是一个内比较器 实现了 Comparable 接口的类有一个特点 就是这些 类是可以和自己比较的 至于具体和另一个实现了 Compar

    2026年3月17日
    1
  • (毕业设计资料)基于单片机SPWM逆变器电源系统设计

    (毕业设计资料)基于单片机SPWM逆变器电源系统设计输出:正弦波频率:可调;幅值:可调;逆变原理:51单片机SPWM驱动H桥+后级滤波;调节方式:频率加按键、频率减按键、幅值加按键、幅值减按键;频率调节范围:10hz、20hz、30hz、40hz、50hz、60hz、70hz、80hz、100hz;幅值调节范围:0%,10%,20%,30%,40%,50%,60%,70%,80%,90%,100%;(输出峰值占输入电压百分比)输出最大电流:2A;过流打嗝保护:过流保护值2A,过流时切断,5秒后尝试恢复输出;输入电压范围:

    2022年4月30日
    49
  • 【5G NR】RRC连接释放

    【5G NR】RRC连接释放当 UE 与基站出现 RRC 重配置失败 切换失败 无线链路失败和完整性保护失败等失败时 将发起 RRCRelease 过程 将 UE 转为 RRC IDLE 或 RRC INACTIVE 状态

    2026年3月19日
    2
  • Windows Xp 优化文件 的一段BAT代码

    Windows Xp 优化文件 的一段BAT代码WindowsXp 优化文件的一段 BAT 代码 echoofftitle 优化文件 startclscolo COLS 50LINES 27echo nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp WindowsXp 优化文件 echo nbsp nbsp nbsp nbsp PoweredByThu e

    2026年3月26日
    1
  • 网页之定时器详解

    网页之定时器详解nbsp nbsp nbsp nbsp nbsp nbsp nbsp 在网页的特效制作中 经常要用到定时器 比如 间隔一定时间后页面自动跳转 或者间隔一定时间出现某种效果等等 nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp 若要页面定时跳转 简单的可以在 head 头部的 meta 标记中设定重定向就可以了 但我要说的是 javascript 中的定时器 它的功能是十分强大和有用的 nbsp nbsp nbsp nbsp nbsp nbsp nbsp 在 javascript 中有两个关于定时器的函数 它们是 nbsp nbsp 1 倒计定时器 timenam

    2026年3月17日
    2
  • linux命令 renice,Linux命令之nice和renice

    linux命令 renice,Linux命令之nice和renice1 nice 命令 nice 选项 命令 参数 在执行程序之前 改变优先级 以调整过的优先级运行命令 如果没有给出命令 就显示当前的优先级 优先级范围从 20 到 19 越小优先级越高 默认为 0 注意 系统允许 root 用户设置负数优先级 以及减小现有进程的优先级数值大小 对普通用户仅允许设置正数优先级 并且只能增大现有进程的优先级数值大小 选项 n adjustment N 将整数 N 添

    2026年3月19日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号