notify产生死锁的场景(备忘)
来源:互联网 发布:star法则 程序员 编辑:程序博客网 时间:2024/06/17 20:01
生产者、消费者数量都为2,缓冲区为1,当按照下列并发顺序执行的时候出现死锁:
1.消费者1获得锁,发现缓冲区为0,wait(wait自动释放锁);
2.消费者2获得锁,发现缓冲区为0,wait(wait自动释放锁);
3.生产者1获得锁,发现缓冲区为0可以生产,生产以后放在缓冲区,notify,现在缓冲区为1;
4.第3步notify唤醒了消费者1,但是消费者1没有抢到锁,锁被生产者2拿到了;
5.生产者2发现缓冲区为1(因为只是唤醒了消费者1,但是消费者1没有抢到锁,没法消费),wait(wait自动释放锁);
6.现在消费者1获得了锁,消费并且notify(此时生产者2和消费者2都处于wait状态),缓冲区为0;
7.很不幸,第6步notify唤醒了消费者2,消费者2醒来后拿到锁发现缓冲区为0,接着wait,与此同时,生产者2也在wait,死锁产生。
可以看出问题的关键在于两个地方,一个是第4步notify并不能保证notify唤醒的线程获得锁,一个是第7步notify可能会唤醒同一种角色的线程。
可以用Lock/Condition解决,两个Condition可以保证notify(signal)不同角色的线程,也可以用notifyAll解决,使线程间变成对锁的竞争。
0 0
- notify产生死锁的场景(备忘)
- 【Linux】关于死锁(基本概念,产生的场景,产生的条件,避免死锁的算法及原理)
- Linux:死锁的产生的场景&如何避免死锁&死锁产生的必要条件
- notify发生死锁的情景
- notify发生死锁的情景
- 操作系统(十)----死锁的产生
- 产生死锁的必要条件
- 关于死锁的产生
- 产生死锁的原因
- 死锁产生的原因
- 产生死锁的条件
- synchronized产生的死锁
- 产生死锁的原因
- 产生死锁的必要条件
- 死锁的产生
- 产生死锁的原因
- 产生死锁的必要条件
- 死锁产生的必要条件
- 十八掌大数据视频免费领
- JAVA编程思想笔记--第一章 对象导论
- CSDN如何转载别人的文章
- JS实现点击显示与隐藏
- 栈-中缀表达式换成后缀
- notify产生死锁的场景(备忘)
- TCP与UDP区别
- css之盒子模型box-sizing属性
- 极客学院:iOS安全攻防
- ubuntu16.04进入命令行
- 搜索引擎原理篇
- 2017成白电突破攻坚年,全方位备战成为重要竞争策略
- lazy ideas in programming
- IP地址合法性(模拟逻辑运算)