JAVA线程死锁问题

R类资源有M个,N个进程互相使用,每个进程对R的最大需求为W,当M=2N=2W=2的时候会发生死锁,但是当M=4N=3,W=2的时候却不会吗?这是为什么呢?互斥使用不是应... R类资源有M个,N个进程互相使用,每个进程对R的最大需求为W,当M=2 N=2 W=2的时候会发生死锁,但是当M=4 N=3,W=2的时候却不会吗?这是为什么呢?互斥使用不是应该不能同时使用,那应该都不可能会造成死锁啊??? 展开
 我来答
abc小鸭
2014-04-04 · 知道合伙人教育行家
abc小鸭
知道合伙人教育行家
采纳数:366 获赞数:4162
毕业于北京理工大学,现从事软件开发工作。

向TA提问 私信TA
展开全部
当M=2 N=2 W=2的时候,假定N个进程分别为N1,N2。
如果N1进程获取到1个R资源,同时N2进程也获取到1个R资源,M=2,W=2,两者都不能满足最大需求,也都不释放资源,都等待R资源,就会造成死锁。

但是当M=4 N=3,W=2的时候,假定N个进程分别为N1,N2,N3。
最坏的情况是,进程N1、N2、N3同是获取到1个R资源,而M=4,W=2,还有一个空闲的R资源,不管是进程N1、N2、N3中的哪个进程获取到空闲资源,都可以满足最大需求,获取到最后一个空闲R资源的进程满足需求,进入运行状态,另外两个进程等待,满足需求的进程运行结束后释放资源,将有两个空闲的R资源,剩下两个等待的进程都能满足需求,所以不会陷入死锁。

互斥使用是不能同时使用,但是如果资源不足,每个进程都占用一部分资源却不能满足需求,而且都不释放自身占用的那部分资源,都陷入等待状态,就会造成死锁。

如果(w-1)*N+1<=M就不会造成死锁,反之,如果(w-1)*N+1>M就有可能造成死锁。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式