如何避免死锁

死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种相互等待的现象,若无外力作用,它们都将无法推进下去。这是一个严重的问题,因为死锁会让你的程序挂起无法完成任务,死锁的发生必须满足以下四个条件:

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

银行家算法避免死锁。

数据结构:

  1. 可利用资源向量Available:这是一个含有m个元素的数组,其中的每一个元素代表一类可利用的资源数目,其初始值是系统中所配置的该类全部可用资源的数目,其数值随该类资源的分配和回收而动态地改变。如果Available[j]=K,则表示系统中现有Rj类资源K个;
  2. 最大需求矩阵Max:这是一个n×m的矩阵,它定义了系统中n个进程中的每一个进程对m类资源的最大需求。如果Max[i, j]=K,则表示进程Pi需要Rj类资源的最大数目为K;
  3. 分配矩阵Allocation:这也是一个n×m的矩阵,它定义了系统中每一类资源当前已分配给每一进程的资源数。如果Allocation[i, j]=K,则表示进程Pi当前已分得Rj类资源的数目为K;
  4. 需求矩阵Need:这也是一个n×m的矩阵,用以表示每一个进程尚需的各类资源数。如果Need[i, j]=K,则表示进程Pi还需要Rj类资源K个,方能完成其任务。

避免死锁最简单的方法就是阻止循环等待条件,将系统中所有的资源设置标志位,排序,规定所有的进程申请资源。

posted @   fjhnb  阅读(114)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示