首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >当这四个条件存在时,死锁一定是真的吗?

当这四个条件存在时,死锁一定是真的吗?
EN

Stack Overflow用户
提问于 2013-06-07 09:02:05
回答 2查看 607关注 0票数 3

我理解发生死锁的四个必要条件:互斥、持有和等待、无抢占和循环等待。然而,是否存在四个条件为真并且系统不处于死锁状态的情况?

换句话说,如果发生死锁,则存在四个条件。但是,如果存在这四个条件,是否一定会出现死锁呢?哪种情况存在,并且系统未处于死锁状态?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-06-07 09:08:50

这些是必要条件,但不是充分条件,因此几乎可以肯定,在某些情况下,这些条件是真的,但不会发生死锁。

满足这些条件的系统仅仅具有死锁状态--可能存在永远不会到达这些死锁状态之一的执行路径。我正在努力合成一个例子,但谢天谢地是someone else did it for me

票数 2
EN

Stack Overflow用户

发布于 2013-06-07 09:14:49

您可以通过绘制优先图来调查是否存在死锁,如果图中有循环,则会出现死锁。你也可能不幸地得到了一个活锁。如果这个图有一个循环,那么这个流程就不能被序列化。因此,要确定某个过程,请绘制其优先图并检查该优先图是否包含循环。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16974668

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档