操作系统笔记:死锁

操作系统笔记
原作者视频地址:https://www.bilibili.com/video/BV1YE411D7nH?spm_id_from=333.337.search-card.all.click
本人为自学整理的文档

第二部分:死锁

死锁的定义

多个进程因竞争资源而造成的一种僵局(互相等待),若无外力作用,这些进程都无法向前推进。
死锁产生的必要条件:互斥条件(独占资源)、不剥夺条件(主动释放资源)、请求并保持条件(保持现有资源申请新资源)、循环等待条件(资源循环等待链)

死锁预防策略

1.破坏互斥条件:将只能互斥的资源改成同时共享访问;独占锁改成共享锁;不是所有资源都能改成可共享的
2.破坏不剥夺条件:请求新资源时必须释放已有资源;由OS协助强制剥夺某进程持有的资源;实现此策略复杂且代价高,而且这个策略操作过多导致原进程任务无法推进
3.破坏请求并保持条件:进程开始运行一次申请所需资源(导致资源浪费和进程饥饿)—>阶段性请求和释放资源
4.破坏循环等待条件:对所有资源进行排序,按序号请求资源(请求时先低后高,释放时先高后低);对资源编号应相对稳定,限制了新设备增加;进程使用资源的顺序与编号顺序不同;限制用户编程

死锁避免

银行家算法 (得到安全序列)
数据结构:
可利用资源向量Available:含有m个元素的数组,每个元素代表一类可用的资源数目。
最大需求矩阵Max:n x m矩阵,定义系统中n个进程中的每个进程对m类资源的最大需求。
分配矩阵Allocation:n x m矩阵,定义系统中每类资源当前已分配给每个进程的资源数。
需求矩阵Need:n x m矩阵,表示每个进程接下来最多还需要多少资源。
银行家算法的主要思想是避免系统进入不安全状态。在每次进行资源分配时,首先检查系统是否有足够的资源满足要求,若有则先进行分配,并对分配后的新状态进行安全性检查。若新状态安全,则正式分配上述资源,否则拒绝分配上述资源。这样保证系统始终处于安全状态,从而避免了死锁现象的发生。

死锁检测和解除

系统死锁可利用资源分配图描述。
在这里插入图片描述

死锁解除

资源剥夺、撤销进程和进程回退
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夜以冀北

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值