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

八股文打卡day22——操作系统(5)

面试题:什么是死锁?如何避免死锁?

我的回答:

死锁是两个或者多个进程都占有各自的资源,然后都互相请求资源,导致互相都陷入了阻塞状态。

如何避免死锁呢
首先,造成死锁有四个必要条件:
1.互斥条件
当一个进程占用某个资源的时候,其他进程是不可能再占用这个资源的。
2.不可剥夺条件
当一个进程占用某个资源时,无法直接剥夺他占用的资源,只能由其主动释放。
3.请求保持条件
当一个进程占用部分资源,然后又请求某些资源时,会占用已有资源,然后进入阻塞状态等待。
4.环路等待条件
多个进程形成一个循环等待的链条,每个进程都在等待下一个进程释放其所占用的资源。

要想避免死锁,就要打破造成死锁的这四个必要条件之一即可
1.打破不可剥夺条件
设置请求倒计时,当一个进程请求一个资源,超过这个倒计时,会强制回收其所占用的资源,让其终止或者重新申请。
2.打破请求保持条件
一次性分配所有的资源给进程,避免占用部分资源,再去申请其他资源,造成循环等待。
3.打破环路等待条件
让多个进程按顺序申请资源,然后反序释放资源。

其他一些避免死锁的策略有
1.资源分配图
通过资源分配图来检测死锁是否存在
2.死锁检测与恢复
完全避免死锁几乎不可能,而且代价太大,所以可以对死锁现象进行检测,检测到了,再采取必要的恢复策略。如:终止某些进程或回滚操作。

回答八股的时间:2024.01.06

http://www.lryc.cn/news/274868.html

相关文章:

  • SQL Server 权限管理
  • ReentrantLock底层原理学习一
  • 数字孪生在增强现实(AR)中的应用
  • 【数据仓库与联机分析处理】多维数据模型
  • 【网络面试(3)】浏览器委托协议栈完成消息的收发
  • Kotlin: Jetpack — ViewModel简单应用
  • 【Java技术专题】「攻破技术盲区」攻破Java技术盲点之unsafe类的使用指南(打破Java的安全管控— sun.misc.unsafe)
  • 私有云平台搭建openstack和ceph结合搭建手册
  • debug mccl 02 —— 环境搭建及初步调试
  • ros python 接收GPS RTK 串口消息再转发 ros 主题消息
  • 2024年网络安全竞赛-页面信息发现任务解析
  • ARM DMA使用整理
  • 移动通信原理与关键技术学习(第四代蜂窝移动通信系统)
  • 光明源@智慧厕所技术:优化生活,提升卫生舒适度
  • 【Bootstrap学习 day13】
  • Shell:常用命令之dirname与basename
  • Linux-v4l2框架
  • VPC网络架构下的网络上数据采集
  • 模拟算法(模拟算法 == 依葫芦画瓢)万字
  • QtApplets-SystemInfo
  • vue3防抖函数封装与使用,以指令的形式使用
  • Hive学习(13)lag和lead函数取偏移量
  • Centos Unable to verify the graphical display setup
  • Java 说一下 synchronized 底层实现原理?
  • nginx访问路径匹配方法
  • 偌依 项目部署及上线步骤
  • PHP特性知识点扫盲 - 上篇
  • Docker一键极速安装Nacos,并配置数据库!
  • 交换机04_远程连接
  • ES6定义一个类(函数内部定义属性,,原型定义方法 ), 实现继承?