大话Java之-Java锁机制(2),
分享于 点击 33552 次 点评:200
大话Java之-Java锁机制(2),
今天聊一下什么是死锁。
顾名思义,某个东西被锁死 打不开,还是拿老张老王买票的例子说明:
车票只剩一张,老张买到了 ,但是有事情要退票,老王需要买一个票,但是小地方的售票和退票窗口都是同一个,并且只有这一个,不巧的时候老王排队在前,所以先占用了窗口,并且很无理的提出要求,没有票就一直在窗口等,老张干着急,不知道前面老王什么情况,又不能插队,导致情况一直僵住。
可能你会想,这两个人不会商量一下吗?现实中当然会,但是对于电脑来讲,电脑是比较笨的。电脑是按照人预先编好的指令去执行,不会变通,所以导致你等我让开窗口,我等你退票,互相等待,导致僵住,这在程序中就叫做死锁。死锁危害很大,会导致系统崩溃,程序无法工作,如果大量的死锁会导致服务挂掉。
产生死锁需要四个条件同时发生:
- 互斥条件:一个车座位只能卖一个人,要么卖给老张,要么卖个老王。
- 不可剥夺条件:如果卖给老张,老王就不能强行夺取。
- 请求和保持条件:老王在窗口买票的时候,没办完之前有权利一直保持占有窗口。
- 循环等待条件:老王等待有人退票,然后买票,老张等待老王办完事情,让出位置然后退票。
以上给出了导致死锁的四个必要条件,死锁产生后,会导致系统崩溃,
专业名词解释:
产生死锁的四个必要条件:
(1) 互斥条件:一个资源每次只能被一个进程使用。
(2) 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
(3) 不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。
(4) 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。
这四个条件是死锁的必要条件,只要系统发生死锁,这些条件必然成立,而只要上述条件之
一不满足,就不会发生死锁。
所以避免死锁是重中之重。如何避免呢?
很简单:破除上述四个条件之一既可以了。下一次讲如何避免死锁。
相关文章
- 暂无相关文章
用户点评