操作系统之死锁

1.什么是死锁?

两个进程各自占用着对方所需要的资源才能释放所占用的资源继续执行下去,此时两个进程进入了无限等待中。。。

2.死锁发生的必要条件?

死锁发生必须同时具备以下三个条件:

  • 存在对不可共享资源的竞争;
  • 这些资源是在不完整的基础上请求的,也就是说,一个进程接受了某些资源后,稍后还将请求其他的资源;
  • 一个资源一旦被分配出去,就不能以强制的方法再收回。

3.解决死锁的方案?

对应上述三个条件的解决方案是:
1.对应条件一: 将不可共享资源转换为可共享的,例如打印机的多个请求缓存进硬盘中,待之后打印机可用时,再将数据从硬盘输出到打印机上。这种保存数据供以后在合适的时候输出的技术称为假脱机。(死锁避免方案)
2. 对应条件二:要求每个进程一次性请求它所需要的全部资源。但这样可能发生“饿死”。(死锁避免方案)
3. 对应条件三:比如进程表满的时候,可以kill一些进程,释放一些进程表的空间,打破死锁并使得剩下的进程可以继续它们的任务。(死锁检测和改正方案)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值