zoukankan      html  css  js  c++  java
  • 死锁

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

    如何检测死锁

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

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

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

     
  • 相关阅读:
    MapReduce测试进度
    MapReduce实验进度
    Hive安装心得及教程分享
    MapReduce实验进程
    个人课程总结
    最长单词链
    用户体验评价
    SSMS无法新建查询问题解决办法征集
    寻找“水王”
    算法和数据结构
  • 原文地址:https://www.cnblogs.com/MJyc/p/7575936.html
Copyright © 2011-2022 走看看