操作系统课程设计银行家算法模拟实现.docx
《操作系统课程设计银行家算法模拟实现.docx》由会员分享,可在线阅读,更多相关《操作系统课程设计银行家算法模拟实现.docx(6页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、操作系统课程设计银行家算法模拟实现 操作系统 课程设计报告 专业 计算机科学与技术 学生姓名 班级 学号 指导老师 完成日期 信息工程学院 题目: 银行家算法的模拟实现 一、设计目的 本课程设计是学习完“操作系统原理”课程后进行的一次全面的综合训练,通过课程设计,更好地驾驭操作系统的原理及实现方法,加深对操作系统基础理论和重要算法的理解,加强学生的动手实力。二、设计内容 1)概述 用C或C+语言编制银行家算法通用程序,并检测所给状态的系统平安性。1. 算法介绍:数据结构:1)可利用资源向量 Available;2)最大需求矩阵Max;3)安排矩阵Allocation;4)需求矩阵Need 2.
2、 功能介绍 模拟实现Dijkstra的银行家算法以避开死锁的出现,分两部分组成:第一部分:银行家算法(扫描);其次部分:平安性算法。2)设计原理 一银行家算法的基本概念 1、死锁概念。在多道程序系统中,虽可借助于多个进程的并发执行,来改善系统的资源利用率,提高系统的吞吐量,但可能发生一种危急死锁。所谓死锁(Deadlock),是指多个进程在运行中因争夺资源而造成的一种僵局(Deadly_Embrace),当进程处于这种僵持状态时,若无外力作用,它们都将无法再向前推动。一组进程中,每个进程都无限等待被该组进程中另一进程所占有的资源,因而恒久无法得到的资源,这种现象称为进程死锁,这一组进程就称为死
3、锁进程。2、关于死锁的一些结论: 参加死锁的进程最少是两个 (两个以上进程才会出现死锁) 参加死锁的进程至少有两个已经占有资源 参加死锁的全部进程都在等待资源 参加死锁的进程是当前系统中全部进程的子集 注:假如死锁发生,会奢侈大量系统资源,甚至导致系统崩溃。3、资源分类。永久性资源:可以被多个进程多次运用(可再用资源)l 可抢占资源 l 不行抢占资源 临时性资源:只可运用一次的资源;如信号量,中断信号,同步信号等(可消耗性资源)“申请-安排-运用-释放”模式 4、产生死锁的四个必要条件:互斥运用(资源独占)、不行强占(不行剥夺)、恳求和保持(部分安排,占有申请)、循环等待。1) 互斥运用(资源
4、独占)一个资源每次只能给一个进程运用。2) 不行强占(不行剥夺)资源申请者不能强行的从资源占有者手中夺取资源,资源只能由占有者自愿释放。3) 恳求和保持(部分安排,占有申请)一个进程在申请新的资源的同时保持对原有资源的占有(只有这样才是动态申请,动态安排)。4) 循环等待 存在一个进程等待队列 P1 , P2 , , Pn, 其中P1等待P2占有的资源,P2等待P3占有的资源,Pn等待P1占有的资源,形成一个进程等待环路。5、死锁预防: 定义:在系统设计时确定资源安排算法,保证不发生死锁。详细的做法是破坏产生死锁的四个必要条件之一。破坏“不行剥夺”条件 在允许进程动态申请资源前提下规定,一个进
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 课程设计 银行家 算法 模拟 实现
限制150内