news 2026/4/16 15:53:19

操作系统期末复习——第6章:死锁

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
操作系统期末复习——第6章:死锁

目录

  • 6.1 资源
  • 6.2 死锁简介
    • 6.2.1 ⭐死锁的定义
    • 6.2.2 ⭐死锁的条件(缺一不可)
    • 6.2.3 资源分配图
    • 6.2.3 解决死锁
  • 6.3 鸵鸟算法
  • 6.4 死锁检测和死锁恢复
    • 6.4.1 死锁检测
    • 6.4.2 ⭐死锁恢复
  • 6.5 ⭐死锁避免
  • 6.6 ⭐死锁预防
    • 6.6.1 破坏互斥条件
    • 6.6.2 破坏占有并等待条件
    • 6.6.3 破坏不可抢占条件
    • 6.6.4 破坏环路等待条件
  • 6.7 其他问题
    • 6.7.1 两阶段加锁Two-Phase Locking
    • 6.7.2 通信死锁Communication Deadlocks
    • 6.7.3 活锁LiveLock
    • 6.7.4 饥饿Starvation
    • 6.7.5 死锁Deadlock

6.1 资源

  1. 可抢占资源

    可以从拥有它的进程中抢占而不会产生任何副作用,如存储器

  2. 不可抢占资源

    在不引起相关的计算失败的话,无法把它从占有它的进程处抢占过来,如蓝光光盘

6.2 死锁简介

6.2.1 ⭐死锁的定义

如果一组进程集合中的每个进程都在等待只能由该进程集合的其他进程才能引发的事件,那么该组进程集合就是死锁的

6.2.2 ⭐死锁的条件(缺一不可)

  1. 互斥条件

  2. 占有和等待条件

  3. 不可抢占条件

  4. 环路等待条件

    • 无环不死锁

    • 有环

      • 一个资源仅一个实例会死锁

      • 一个资源有多个实例可能不死锁

6.2.3 资源分配图

  1. 圆形是进程,方形是资源

  2. 资源指向进程:占有资源
    进程指向资源:请求资源

6.2.3 解决死锁

  1. 忽略问题,假装没发生死锁

    鸵鸟算法

  2. 允许进入死锁,检测然后恢复

  3. 确保不进入死锁

    • 避免(仔细分配资源)

    • 预防(破坏四个条件之一)

6.3 鸵鸟算法

  1. 使用鸵鸟算法原因

    • 死锁不经常发生

    • 预防成本高

  2. UNIX和Windows使用该方法

  3. 是便利性和正确性的折中

6.4 死锁检测和死锁恢复

6.4.1 死锁检测

  1. 简介

    • 允许进入死锁,执行死锁检测算法。检测到死锁后执行恢复算法

    • 运行检测算法代价大,成本高

  2. 流程

    DFS算法

6.4.2 ⭐死锁恢复

  1. ⭐利用抢占恢复

  2. ⭐利用回滚恢复(回到上一状态)

  3. ⭐通过杀死进程恢复

6.5 ⭐死锁避免

  1. 资源轨迹图

  2. 安全状态和不安全状态

    从安全状态出发,系统能保证所有进程完成。而不安全状态存在死锁的风险(但仍可能所有进程都完成)。(注意:不安全状态≠死锁)

  3. 银行家算法

    实用性不高

    • 很少有进程在运行前就知道其所需资源的最大值

    • 进程数量不固定

    • 可用资源可能会消失(机器会坏)

6.6 ⭐死锁预防

6.6.1 破坏互斥条件

  1. 假脱机技术

    • 假脱机打印机允许若干个进程同时产生输出

    • 由守护进程按顺序处理请求

    • 若假脱机内存空间满也会出现死锁

  2. 原理

    • 非绝对必要时避免分配资源

    • 实际占用资源的进程尽可能少

  3. 问题

    不是所有设备都可以假脱机

6.6.2 破坏占有并等待条件

  1. 进程执行前请求所有的资源

  2. 问题

    • 开始执行时可能不知道所需资源

    • 占用其他进程的资源,资源利用率差(请求所有的资源,就会占用别的进程的资源)

  3. 变体

    请求资源前先释放当前持有的资源,然后再请求所有所需资源

6.6.3 破坏不可抢占条件

  1. 强行抢占

    实践中难以实现

  2. 资源虚拟化

    • 假脱机打印机向磁盘输出,并仅允许守护进程访问真实打印机(可以抢占进程顺序?)

    • 问题

      • 并非所有资源都可以虚拟化

6.6.4 破坏环路等待条件

  1. 法1:一次请求一个资源。请求下一个资源时释放当前资源

  2. 法2:资源进行编号,按升序请求

  3. 法3:法2的变体,取消升序,按大于等于

  4. 问题

    • 很难/不可能找到合适的编号满足所有进程需求

    • 增加程序员了解编号的负担

6.7 其他问题

6.7.1 两阶段加锁Two-Phase Locking

  1. 第一阶段:对所有所需记录加锁

    若某个记录已加锁,就释放所有加锁记录,重新开始第一阶段

  2. 第二阶段:完成更新然后释放锁

6.7.2 通信死锁Communication Deadlocks

  1. 一组进程互相等待对方发送的消息,但这些消息因丢失、延迟或逻辑错误永远无法到达

  2. 解决方案:超时机制(Timeout)

6.7.3 活锁LiveLock

一组进程未阻塞,但通过无效的重复操作互相礼让资源,导致进程不会继续执行

6.7.4 饥饿Starvation

某个进程因资源长期被高优先级进程抢占而无法获得所需资源,导致任务延迟或无法完成

6.7.5 死锁Deadlock

一组进程因相互等待对方持有的资源而全部阻塞,无法继续执行


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 14:51:12

QLVideo完全指南:解锁macOS视频预览新境界

QLVideo完全指南:解锁macOS视频预览新境界 【免费下载链接】QLVideo This package allows macOS Finder to display thumbnails, static QuickLook previews, cover art and metadata for most types of video files. 项目地址: https://gitcode.com/gh_mirrors/q…

作者头像 李华
网站建设 2026/4/15 12:18:00

Chatbox数据持久化:从对话丢失到永久保存的技术演进

Chatbox数据持久化:从对话丢失到永久保存的技术演进 【免费下载链接】chatbox Chatbox是一款开源的AI桌面客户端,它提供简单易用的界面,助用户高效与AI交互。可以有效提升工作效率,同时确保数据安全。源项目地址:https…

作者头像 李华
网站建设 2026/4/15 17:20:32

如何用M2FP优化视频会议中的人物分割?

如何用M2FP优化视频会议中的人物分割? 🌐 背景与挑战:虚拟背景为何需要精准人体解析? 在远程办公和在线教育日益普及的今天,视频会议已成为日常沟通的核心工具。其中,“虚拟背景”功能因其能保护隐私、提升…

作者头像 李华
网站建设 2026/4/15 9:58:07

3个技巧轻松掌控三星耳机:桌面端完整管理终极指南

3个技巧轻松掌控三星耳机:桌面端完整管理终极指南 【免费下载链接】GalaxyBudsClient Unofficial Galaxy Buds Manager for Windows, macOS, and Linux 项目地址: https://gitcode.com/gh_mirrors/gal/GalaxyBudsClient 你是否曾经在使用电脑时,想…

作者头像 李华
网站建设 2026/4/16 6:04:13

Windirstat中文版:AI技术如何让磁盘分析工具更懂中国用户

Windirstat中文版:AI技术如何让磁盘分析工具更懂中国用户 【免费下载链接】windirstat WinDirStat is a disk usage statistics viewer and cleanup tool for various versions of Microsoft Windows. 项目地址: https://gitcode.com/gh_mirrors/wi/windirstat …

作者头像 李华
网站建设 2026/4/16 6:01:20

服务设计的敏捷化:让运维跟上业务变化的节拍

点击文末阅读原文免费下载ITIL流程设计体系文档8个在这个数字化转型的浪潮中,我见过太多企业被自己的IT架构拖了后腿。业务部门提出新需求,运维团队却需要几周甚至几个月才能交付;市场机会稍纵即逝,技术却成了最大的瓶颈。这种错位…

作者头像 李华