感谢 ♥ 作者
先不感谢了

死锁

产生死锁的四个必要条件:
  (1) 互斥条件:一个资源每次只能被一个进程使用。
  (2) 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
  (3) 不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。
  (4) 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。

如何检测死锁

  有两个容器,一个用于保存线程正在请求的锁,一个用于保存线程已经持有的锁。每次加锁之前都会做如下检测:

    1)检测当前正在请求的锁是否已经被其它线程持有,如果有,则把那些线程找出来

    2)遍历第一步中返回的线程,检查自己持有的锁是否正被其中任何一个线程请求,如果第二步返回真,表示出现了死锁

 
posted @ 2017-09-22 17:16  MJyc  阅读(90)  评论(0编辑  收藏  举报