黑马程序员技术交流社区

标题: 多线程的死锁问题 [打印本页]

作者: 1453149997    时间: 2014-4-2 14:38
标题: 多线程的死锁问题
本帖最后由 1453149997 于 2014-4-3 16:56 编辑

(1)死锁可以在锁嵌套的情况下发生,那么除了这种情况还有其它情况吗?

(2)避免锁的嵌套可以在一定程度上解决减少死锁的发生,但是解决死锁还有其它方法吗?如果死锁的问题不是由锁的嵌套引起,那么该如何解决死锁问题?
作者: 一世英明    时间: 2014-4-2 15:10
1.产生死锁的的4个必要条件:
(1) 互斥条件:一个资源每次只能被一个进程使用.
(2) 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放.
(3)不剥夺条件:进程以获得的资源,在未使用完之前,不能强行剥夺.
(4)循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系.

这四个条件是死锁的必要条件,只要系统发生死锁,这些条件必然成立,而只要上述条件
之一不满足,就不会发生死锁!!

作者: Saner    时间: 2014-4-2 15:41
死锁的主要原因是锁嵌套,多个线程在相互等资源,如何尽量避免死锁:
1.利用OOP技术,资源尽量封装到类中。
2.针对接口编程设计到资源的操作和访问都通过接口访问,接口内加锁,资源访问对外透明。
3.多个线程竞争性的资源,可以适当采用单件方式。
4.避免过多的函数嵌套。
5.函数内使用资源尽量使用面向对象的方式管理锁的生命周期。





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2