notify和notifyAll的区别

网友投稿 614 2022-10-23

notify和notifyAll的区别

notify和notifyAll的区别

介绍

锁池EntryList 等待池WaitSet

锁池

假设线程A已经拥有了某个对象(不是类)的锁,而其他线程B,C想要调用这个对象的某个synchronized方法(或者块),由于B,C线程在进入对象的synchronized方法(或者块)之前就必须先获得该对象锁的拥有权,而恰巧该对象的锁目前正被线程A所占用,此时B,C线程就会被阻塞,进入一个地方去等待锁的释放,这个地方便是该对象的锁池

等待池 假设线程A调用了某个对象的wait()方法,线程A就会释放该对象的锁,同时线程A就进入到了该对象的等待池中,进入到等待池中的线程不会去竞争改对象的锁

notifyAll会让所有处于等待池的线程全部进入锁池去竞争获取锁的机会

notify只会随机选取一个处于等待池中的线程进入锁池去竞争获取锁的机会

例子

我们用例子演示说明

开3个等待的线程,一个通知的线程,通知的线程里面调用notify方法

public class ShowDemo { public static void main(String[] args) { Object lock = new Object(); Runnable waitTask = new Runnable() { @Override public void run() { synchronized (lock) { try { System.out.println(Thread.currentThread().getName() + " wait"); lock.wait(); System.out.println(Thread.currentThread().getName() + " notify"); } catch (InterruptedException e) { e.printStackTrace(); } } } }; Runnable notifyTask = new Runnable() { @Override public void run() { synchronized (lock) { // lock.notifyAll(); 换成这个所有线程都结束 lock.notify(); } } }; Thread thread1 = new Thread(waitTask, "thread1"); Thread thread2 = new Thread(waitTask, "thread2"); Thread thread3 = new Thread(waitTask, "thread3"); thread1.start(); thread2.start(); thread3.start(); // 确保thread1,thread2,thread3都启动后,启动thread4 try { TimeUnit.SECONDS.sleep(1); } catch (InterruptedException e) { e.printStackTrace(); } Thread thread4 = new Thread(notifyTask, "thread4"); thread4.start(); }}

看到只有一个线程结束了,其余2个线程一直阻塞。

thread2 waitthread3 waitthread1 waitthread2 notify

将notifyTask中的notify换成notifyAll,输入如下,可以看到3个线程都正常结束

thread1 waitthread2 waitthread3 waitthread3 notifythread2 notifythread1 notify

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:基于springboot-dubbo-mybatis构架一个通用的开发开发框架
下一篇:Serializer++:用于C++的小型、轻巧和易于理解的数据序列化库
相关文章

 发表评论

暂时没有评论,来抢沙发吧~