1、 操作系统课程设计操作系统课程设计 题目:题目: 银行家算法银行家算法 院 ( 部 ) 系 信息工程学院信息工程学院 所 学 专 业 信息管理与信息系统信息管理与信息系统 年 级 、 班 级 学号 学 生 姓 名 指导教师姓名 1、概述概述 一、设计目的一、设计目的 1、了解多道程序系统中,多个进程并发执行的资源分配。 2、掌握死锁的产生的原因、产生死锁的必要条件和处理死锁的基本方法。 3、掌握预防死锁的方法,系统安全状态的基本概念。 4、掌握银行家算法,了解资源在进程并发执行中的资源分配策略。 5、理解死锁避免在当前计算机系统不常使用的原因 二、开发环境二、开发环境 操作系统操作系统 编译环
2、境编译环境 生成文件生成文件 Windows xp Vb 银行家算法.exe 源文件:银行家算法.vbp 2、需求分析、需求分析 避免多道程序系统中程序的死锁。 一、死锁概念:一、死锁概念: 在多道程序系统中,虽可借助于多个进程的并发执行,来改善系统的 资源利用率,提高系统的吞吐量,但可能发生一种危险死锁。所谓死 锁(Deadlock),是指多个进程在运行中因争夺资源而造成的一种僵局 (Deadly_Embrace),当进程处于这种僵持状态时,若无外力作用,它们都将 无法再向前推进。一组进程中,每个进程都无限等待被该组进程中另一进 程所占有的资源,因而永远无法得到的资源,这种现象称为进程死锁,
3、这 一组进程就称为死锁进程。 二、关于死锁的一些结论:二、关于死锁的一些结论: 参与死锁的进程最少是两个(两个以上进程才会出现死锁) 参与死锁的进程至少有两个已经占有资源 参与死锁的所有进程都在等待资源 参与死锁的进程是当前系统中所有进程的子集 注:如果死锁发生,会浪费大量系统资源,甚至导致系统崩溃。 三、资源分类:三、资源分类: 永久性资源: 可以被多个进程多次使用(可再用资源) l 可抢占资源 l 不可抢占资源 临时性资源:只可使用一次的资源;如信号量,中断信号,同步信号等(可消耗 性资源) “申请-分配-使用-释放”模式 四、产生死锁的四个必要条件:四、产生死锁的四个必要条件: 1、互斥
4、使用(资源独占) 一个资源每次只能给一个进程使用 2、不可强占(不可剥夺) 资源申请者不能强行的从资源占有者手中夺取资源,资源只能由占有者自愿释 放 3、请求和保持(部分分配,占有申请) 一个进程在申请新的资源的同时保持对原有资源的占有(只有这样才是动态申 请,动态分配) 4、循环等待 存在一个进程等待队列 P1 , P2 , , Pn, 其中 P1 等待 P2 占有的资源,P2 等待 P3 占有的资源,Pn 等待 P1 占有的资 源,形成一个进程等待环路 5、 死锁的解决方案 5.1 产生死锁的例子 申请不同类型资源产生死锁 P1: 申请打印机 申请扫描仪 使用 释放打印机 释放扫描仪 P2
5、: 申请扫描仪 申请打印机 使用 释放打印机 释放扫描仪 申请同类资源产生死锁(如内存) 设有资源 R,R 有 m 个分配单位,由 n 个进程 P1,P2,Pn(n m)共享。假设 每个进程对 R 的申请和释放符合下列原则: * 一次只能申请一个单位 * 满足总申请后才能使用 * 使用完后一次性释放 m=2,n=3 资源分配不当导致死锁产生 5.2 死锁预防: 定义:在系统设计时确定资源分配算法,保证不发生死锁。具体的做法是破坏产生 死锁的四个必要条件之一 破坏“不可剥夺”条件 在允许进程动态申请资源前提下规定,一个进程在申请新的资源不能立即得到 满足而变为等待状态之前,必须释放已占有的全部资
6、源,若需要再重新申请 破坏“请求和保持”条件 要求每个进程在运行前必须一次性申请它所要求的所有资源,且仅当该进程所 要资源均可满足时才给予一次性分配 破坏“循环等待”条件 采用资源有序分配法: 把系统中所有资源编号, 进程在申请资源时必须严格按资源编号的递增次序进 行,否则操作系统不予分配。 6安全状态与不安全状态 安全状态: 如果存在一个由系统中所有进程构成的安全序列 P1,Pn,则系统处于安全 状态。一个进程序列P1,Pn是安全的,如果对于每一个进程 Pi(1in),它 以后尚需要的资源量不超过系统当前剩余资源量与所有进程 Pj (j 3 状态 b 不安全,只剩 1 个可用资源,收不回已分配资源。 (2)考虑下列系统状态 分配矩阵 最大需求矩阵 可用资源矩阵 0 0 1 2 0 0 1 2 1 5 2 0