当前位置: 首页 > news >正文

死锁的避免

1. 核心思想

        死锁避免属于动态预防策略

  • 不破坏死锁必要条件,而是在资源分配前动态检查安全性
  • 仅当分配资源后系统仍处于安全状态时,才允许分配;否则让进程等待。

2. 系统安全状态与安全序列

(1)安全状态
  • 定义:系统能按某种进程推进顺序(安全序列) 为所有进程分配资源,使每个进程都能顺利完成。
  • 安全序列:存在一个进程序列 ( {P_1, P_2, ..., P_n} ),使得每个进程 ( P_i) 的剩余资源需求可通过当前系统可用资源 + 所有 ( P_j (j < i) ) 已分配资源满足。

  • 系统资源总量:(10, 5, 7)
  • 已分配资源:P1: (2, 1, 2), P2: (3, 0, 2), P3: (2, 1, 1)
  • 剩余需求:P1: (3, 4, 7), P2: (1, 2, 2), P3: (0, 1, 1)
  • 可用资源:(3, 3, 2)
  • 安全序列( P2 \rightarrow P3 \rightarrow P1 )(P2完成后释放资源,满足P3;P3完成后释放资源,满足P1)。

(2)不安全状态
  • 定义:系统找不到任何安全序列,可能导致死锁(但未必已发生死锁)。

3. 银行家算法(Banker's Algorithm)

模拟银行放贷策略,确保资源分配后系统仍安全。

(1)核心数据结构
  • Available:可用资源向量(当前系统空闲资源)。
  • Max:最大需求矩阵(每个进程对各类资源的最大需求)。
  • Allocation:分配矩阵(每个进程已获得的资源)。
  • Need:需求矩阵(每个进程仍需的资源,( Need[i][j] = Max[i][j] - Allocation[i][j] ))。
(2)分配步骤
  1. 进程请求资源:进程 ( P_i ) 发出请求向量 ( Request[i] )。
  2. 初步检查
  • 若 ( Request[i][j] > Need[i][j] )(请求超出需求),拒绝。
  • 若 ( Request[i][j] > Available[j] )(资源不足),进程等待。

     3.  试探分配:假设分配资源:

Available[j] -= Request[i][j] 
Allocation[i][j] += Request[i][j] 
Need[i][j] -= Request[i][j]

  4.安全性检查:判断分配后系统是否存在安全序列:

  • 初始化 Work = AvailableFinish[i] = false
  • 寻找满足 ( Need[i][j] \leq Work[j] ) 且 ( Finish[i] = false ) 的进程 (P_i)。
  • 假设 ( P_i ) 完成,释放资源:( Work[j] += Allocation[i][j] ),标记 ( Finish[i] = true )。
  • 重复上述步骤,若所有 ( Finish[i] = true ),则系统安全,允许分配;否则撤销试探,进程等待。

4. 安全状态与死锁的关系

  • 安全状态 → 一定不会死锁。
  • 不安全状态 → 可能死锁(但非必然,取决于进程推进顺序)。
  • 银行家算法的目标:确保系统始终处于安全状态,从而避免死锁。

详细银行家算法请看-- 银行家算法详解-CSDN博客


核心考点 📌

  1. 安全序列的判断:根据资源分配情况,能否找到一个进程推进顺序使所有进程完成。
  2. 银行家算法步骤:请求检查 → 试探分配 → 安全性检查 → 决定是否分配。
  3. 安全状态的意义:是避免死锁的核心,系统必须在安全状态下才能分配资源。

总结

        死锁避免通过动态检查资源分配安全性来预防死锁,不破坏必要条件。系统安全状态指存在进程执行序列(安全序列)使所有进程都能完成,银行家算法模拟银行放贷策略,在分配资源前检查系统是否仍安全。其核心步骤包括请求检查、试探分配和安全性检查,确保每次分配后系统存在安全序列。安全状态一定不会死锁,不安全状态可能死锁。银行家算法通过维持安全状态避免死锁。

一句话记忆:死锁避免通过银行家算法动态检查资源分配安全性,确保系统始终存在安全序列,从而在不破坏死锁条件的前提下避免死锁! ✨

http://www.dtcms.com/a/275939.html

相关文章:

  • Spring Boot 应用中,配置的加载优先级
  • 锁相环初探
  • CTFHub————Web{信息泄露[Git泄露(Stash、Index)]}
  • Java 接口详解:从基础到高级,掌握面向对象设计的核心契约
  • 使用FastAdmin框架开发二
  • ollama - sqlcoder模型:面向提示词编程(根据用户信息生成sql语句并执行返回结果)
  • SQL新手入门详细教程和应用实例
  • 微信小程序121~130
  • [Vroom] 时间窗口 | 载重与货量管控 | 内部路由表示机制 | 增量式更新算法O(1)
  • 【Redis-05】高可用方案-主从哨兵
  • 【PTA数据结构 | C语言版】用两个栈实现队列
  • 监控28181连接到云服务器/推流分发/客户端网页端手机端拉流/实时性好极低延迟
  • 初等行变换会改变矩阵的什么?不变改变矩阵的什么?求什么时需要初等行变换?求什么时不能初等行变换?
  • GRPO PPO
  • Python 是动态类型的语言,它和静态类型语言(如 C++/Java)有什么优缺点?
  • CSS动画下划线
  • hot100链表(1)
  • 通过自制Flash算法文件,成功实现H7-TOOL脱机烧录nRF54L15,且支持自动解除SWD接口保护(2025-07-12)
  • Google MUVERA: 让多向量检索与单向量检索一样快
  • 2025Stockapi股票数据接口,股票实时数据,技术指标macd,kdj,cci技术指标算法,集合竞价数据,龙虎榜数据接口
  • TensorFlow2 study notes[2]
  • 启动Haproxy失败,如何排查问题
  • TCP与UDP协议详解:网络世界的可靠信使与高速快递
  • 参数化类型有哪些?自动化脚本如何实现数据参数化?
  • houdini vat 学习笔记
  • 滤波电路Multisim电路仿真实验汇总——硬件工程师笔记
  • Spring Security 安全认证深度解析与实战指南
  • 深入解析Java的G1收集器:原理、实战与优缺点
  • Pytest 跳过测试技巧:灵活控制哪些测试该跑、哪些该跳过
  • MCP调研及实践