操作系统课程设计--银行家算法 (2)
《操作系统课程设计--银行家算法 (2)》由会员分享,可在线阅读,更多相关《操作系统课程设计--银行家算法 (2)(17页珍藏版)》请在毕设资料网上搜索。
1、设计题目: 银行家算法 一、一、设计目的设计目的 本课程设计是学习完“操作系统原理”课程后进行的一次全面的综合训练, 通过课程设计,更好地掌握操作系统的原理及实现方法,加深对操作系统基础理 论和重要算法的理解,加强学生的动手能力。 二、二、设计内容设计内容 1 1)概述)概述 用 C 或 C+语言编制银行家算法通用程序,并检测所给状态的系统安全性。 1. 算法介绍:数据结构: 1) 可利用资源向量 Available; 2) 最大需求矩阵 Max; 3) 分配矩阵 Allocation; 4) 需求矩阵 Need 2. 功能介绍 模拟实现 Dijkstra 的银行家算法以避免死锁的出现,分两部
2、分组成: 第一部分:银行家算法(扫描); 第二部分:安全性算法。 2 2)设计原理)设计原理 一银行家算法的基本概念一银行家算法的基本概念 1、死锁概念。 在多道程序系统中,虽可借助于多个进程的并发执行,来改善系统的资源利 用率, 提高系统的吞吐量, 但可能发生一种危险死锁。 所谓死锁(Deadlock), 是指多个进程在运行中因争夺资源而造成的一种僵局(Deadly_Embrace),当进程 处于这种僵持状态时,若无外力作用,它们都将无法再向前推进。一组进程中, 每个进程都无限等待被该组进程中另一进程所占有的资源, 因而永远无法得到的 资源,这种现象称为进程死锁,这一组进程就称为死锁进程。
3、2、关于死锁的一些结论: 参与死锁的进程最少是两个 (两个以上进程才会出现死锁) 参与死锁的进程至少有两个已经占有资源 参与死锁的所有进程都在等待资源 参与死锁的进程是当前系统中所有进程的子集 1 注:如果死锁发生,会浪费大量系统资源,甚至导致系统崩溃。 3、资源分类。 永久性资源: 可以被多个进程多次使用(可再用资源) 可抢占资源 不可抢占资源 临时性资源:只可使用一次的资源;如信号量,中断信号,同步信号等(可消耗 性资源) “申请-分配-使用-释放”模式 4、产生死锁的四个必要条件:互斥使用(资源独占)、不可强占(不可剥夺)、 请求和保持(部分分配,占有申请)、循环等待。 1) 互斥使用(
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中设计图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统课程设计-银行家算法 2 操作系统 课程设计 银行家 算法
