现代操作系统 第六章 死锁

死锁

什么是死锁?A请求实验刻录机,但该请求在B释放光盘刻录机前拒绝,但是进程B非但不放弃刻录机还去申请扫描仪,两个进程被阻塞,并且一直处于这样的状态,这就是死锁(dead lock)

资源

需要排他性使用的对象称为资源(resource),即硬件设备或是一组信息,简单来说就是随着时间的推移必须能获得、使用以及释放的任何东西。

可抢占资源和不可抢占资源

资源分两类:可抢占的和不可抢占的。
可抢占资源(preemptable resource)可以从拥有它的进程中抢占而不会产生任何副作用。
不可抢占资源(nonpreemptable resource)是指在不引起相关的计算失败的情况下,无法把它从占有它的进程处抢占过来。
使用一个资源所需要的事件顺序:

  1. 请求资源;
  2. 使用资源;
  3. 释放资源。

若请求时资源不可用,则请求进程被迫等待。当一个进程请求资源失败时,它通常会处于这样一个小循环中:请求资源、休眠、再请求。

资源获取

如果只有一个进程,就没有必要慎重地获取资源,因为不存在资源竞争。

编码风格上的细微差别(哪一个资源先获取)造成了可以执行的程序和不能执行而且无法检测错误的程序之间的差别。

死锁简介

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值