操作系统原理课程设计实践报告.docx

上传人:夺命阿水 文档编号:979575 上传时间:2024-02-20 格式:DOCX 页数:8 大小:154.32KB
返回 下载 相关 举报
操作系统原理课程设计实践报告.docx_第1页
第1页 / 共8页
操作系统原理课程设计实践报告.docx_第2页
第2页 / 共8页
操作系统原理课程设计实践报告.docx_第3页
第3页 / 共8页
操作系统原理课程设计实践报告.docx_第4页
第4页 / 共8页
操作系统原理课程设计实践报告.docx_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《操作系统原理课程设计实践报告.docx》由会员分享,可在线阅读,更多相关《操作系统原理课程设计实践报告.docx(8页珍藏版)》请在课桌文档上搜索。

1、操作系统原理课程设计实战报告题目:侪真多进程并发环境中死锁的预防、防止、枪测与解除姓针学院:信息科技学院专业:计算机科学技术系JjI级:学号:指导教师:取肌20010年4月8日仿真多进程并发环境中死锁的预防、防止、检测与解除摘要:在多道程序系统中,多个程序并发执行时可能造成死锁。所谓死锁是指多个进程在运行过程中因争夺资源而造成的一种僵局。当进程处于这种僵局状态时假设无外力作用,它们都将无法再向前推进,造成资源的浪费。该程序将模拟多进程并发时死锁现象的产生、防止、检测与解除。死锁防止用最著名的银行家算法,用银行家平安性算法类似的死锁检测算法来检测进程状况,又用资源剥夺法来实现死锁的解除。该程序实

2、现操作简易,表示清晰并且形象描述多进程并发环境中死锁的预防、防止、检测与解除。关键字:死锁;防止死锁;平安状态;银行家算法引言:在操作系统、数据库系统以及网络通信中,由于进程并发和资源共享,当系统中资源分配顺序或者进程推进顺序不当就会造成系统死锁。处于死锁状态的系统中,进程之间互相等待资源而永远不能继续向前推进,严重地影响了系统的可靠性。因而有时需要合理的对资源进行分配必要的时候加以限制保证系统平安、高效、稳定的运行。1理论分析1.1 死锁的概念如果一个进程集合中的每个进程都在等待只能由此集合中的其他进程才能引发的事件,而无限期陷入僵持的局面称为死锁。1.2 产生死锁的条件:1、互斥使用(资源

3、独占):一个资源每次只能给一个进程使用。2、不可强占(不可剥夺):资源申请者不能强行的从资源占有者手中夺取资源,资源只能由占有者自愿释放。3、请求和保持(局部分配,占有申请):一个进程在申请新的资源的同时保持对原有资源的占有(只有这样才是动态申请,动态分配)。4、循环等待:存在一个进程等待队列P1,P2,,Pn,其中PI等待P2占有的资源,P2等待P3占有的资源,Pn等待Pl占有的资源,形成一个进程等待环路。13死锁的预防在系统设计时确定资源分配算法,保证不发生死锁。具体的做法是破坏产生死锁的四个必要条件之一。破坏“不可剥夺”条件在允许进程动态申请资源前提下规定,一个进程在申请新的资源不能立即

4、得到满足而变为等待状态之前,必须释放已占有的全部资源,假设需要再重新申请。破坏“请求和保持”条件要求每个进程在运行前必须一次性申请它所要求的所有资源,且仅当该进程所要资源均可满足时才给予一次性分配。破坏“循环等待”条件采用资源有序分配法:把系统中所有资源编号,进程在申请资源时必须严格按资源编号的递增次序进行,否那么操作系统不予分配。14平安状态与不平安状态所谓5状态,是指或程能按某种进程次序(pl,p2,pn),来为每个进程pi分配其所需资源,直至满足进程Pi对资源的最大需求量,使每个进程Pi可顺利地完成,那么此时系统处于平安状态,称序列(pl,p2,pn)为平安序列.如果系统无法找到这样一个

5、平安序列,那么称系统处于不平安状态2功能设计及其数据结构设计2.1功能设计程序主要提供并发环境的仿真,死锁的检测,银行家算法解决,死锁的解除等功能。仿真多进程并发环境中死钳的预防、避免、检测与解除第一蟀源OOOOO第二类资源 第三类缠 采用资源 剥夺进程0 O 0/7 ,uf5 0/3申请资源进程 1 O 3 i!f2 0/2申请资源剥夺I进程2 O 0/9 ,uf 0/2申请资源-i I进程3 O 0/2 i!f,02 0/2进程4 O 0/4 ,03 0/3申请资源申请资源刹夺复制日志I 潸空日志同要说明:第一类奥源第二类夷源 第三类资源 颗空闲 C)更源被占用C)资源最大誓求7王意事顶:

6、更摭算法时请先初始化用无措施算法时容易造成死锁录恃按钮是将该进程资源施放并挂起了解更多请阅读使用说明。无措施方案 银行家算法 自动检测解除I 初始化 :2. 2数据结构设计进程类Struction_pro属性:ID,Pl,P2,P3,State类Struction属性:P1,P2,P3StructionResource=newStrUCtion(Io,5,7);用于存放每种资源最大值StructionAvailable=newStruction(10,5,7);用于存放每种资源可用值Struction_proClaim=newStruction_pro5;用于存放进程集合信息StrUCtion

7、_proAllocation=newStrUCtion_pro5;用于存放进程集合已非配资源信息3核心算法3.1银行家算法死锁的防止主要采用银行家算法,流程图如下:银行家算法的根本思想是分配资源之前,判断系统是否是平安的;假设是,才分配。它是最具有代表性的防止死锁的算法。设进程cusneed提出请求REQUESTi,那么银行家算法按如下规那么进行判断。(1)如果REQUESTcusneedi=NEEDcusneedi,那么转(2);否那么,出错。(2)如果REQUESTcusneedi=AVAILABLEtcusneedi,那么转(3);否那么,出错。(3)系统试探分配资源,修改相关数据:AV

8、AILABLEi-=REQUESTcusneedi;ALLOCATIONcusneedi+=REQUESTcusneedi;NEEDcusneedi-=REQUESTcusneedi;(4)系统执行平安性检查,如平安,那么分配成立;否那么试探险性分配作废,系统恢复原状,进程等待。平安性算法流程图:死锁检测:允许死锁发生,操作系统不断监视系统进展情况,判断死锁是否发生一旦死锁发生那么采取专门的措施,解除死锁并以最小的代价恢复操作系统运行死锁检测算法与银行家平安性算法类似。死锁检测时机有:当进程等待时检测死锁、定时检测、系统资源利用率下降时检测死锁。该程序才用定时检测。死锁解除有:重新启动、撤消进

9、程、剥夺资源、进程回退。该程序中可使用重新启动或者剥夺资源两中方法。死锁检测与解除往往配套使用,当死锁被检测到之后,采用各种方法解除系统的死锁。4调试分析4.1无措施运行:进程。请求1个P2失败进程2请求6个Pl失败进程1请求2个P3成功并且分配进程。请求1个P3成功并且分配进程。请求2个P2失败进程。请求1个Pl成功并且分配进程4请求1个P3成功并且分配进程4请求2个P2成功并且分配进程4请求1个Pl成功并且分配进程2请求1个P3成功并且分配进程2请求7个Pl失败进程1请求3个Pl成功并且分配进程。请求2个P3成功并且分配进程。请求3个P2成功并且分配进程。请求5个Pl成功并且分配运行无措施

10、方案系统完成初始化选择无措施方案,点击运行各进程资源进行申请资源分配资源,出现资源缺乏情况,造成死锁。4. 2银行家算法:进程4完成并且释放资源进程4蠡求资源到达要求进程开始运行确定为进程4分配2块Pl资源此次请求后存在平安序列:4尝试为进程4分配2块Pl资源进程2完成并且释放资源进程2镭求资源到达要求进程开始运行确定为进程2分配2块Pl资源此次请求后存在平安序列:2 4尝试为进程2分配2块Pl资源此次资源请求后不存在平安序列,系统拒接此次资源请求尝试为进程4分配3块P3资源此次请求后存在平安序列:1 4 2尝试为进程4分配3块P2资源进程3完成并且释放资源进程3豳求资源到达要求进程开始运行尝

11、试为进程3分配O块P2资源此次请求后存在平安序列:3 14 2尝试为进程3分配O块P2资源此次资源请求后不存在平安序列,系统拒接此次资源请求尝试为进程4分配4块P2资源确定为进程1分配2块Pl资源此次请求后存在平安序列:13 2 4尝试为进程1分配2块Pl资源进程。完成并且释放资源进程O需求资源到达要求进程开始运行确定为进程O分配1块Pl资源此次请求后存在平安序列:0 3 14 2尝试为进程。分配1块Pl资源此次资源请求后不存在平安序列,系统拒接此次资源请求尝试为进程4分配1块Pl资源尝试为进程。分配2块P3资源此次请求后存在平安序列:0 3 14 2尝试为进程4分配3块P3资源此次请求后存在

12、平安序列:0 3 14 2尝试为进程4分配3块P2资源此次资源请求后不存在平安序列,系统拒接此次资源请求尝试为进程4分配3块P2资源此次资源请求后不存在平安序列,系统拒接此次资源请求尝试为进程4分配3块Pl资源确定为进程3分配2块PI资源此次请求后存在平安序列:0 3 14 2尝试为进程3分配2块Pl资源确定为进程2分配1块Pl资源确定为进程0分配4块Pl资源此次请求后存在平安序列:0 2 4 1 3尝试为进程。分配4块Pl资源运行银行家算法系统初始化完成进程。完成并且释放资源进程0需求资源到达要求进程开始运行不存在死锁检测死锁程序启动不存在死锁检测死锁程序启动运行银行家算法,日志显示每次进程

13、申请资源都会进行尝试分配然后计算平安性算法,存在的话那么进行分配否那么恢复操作。资源到达条件后那么运行,不会出现死锁状况。4.2自动检测解除:进程0请求1个P2成功并且分配进程0请求1个P2成功并且分配进程0请求1个Pl成功并且分配不存在死锁检测死锁程序启动进程0请求2个Pl成功并且分配不存在死锁检测死锁程序启动进程O请求3个P3成功并且分配进程。请求1个P2成功并且分配进程。请求4个Pl成功并且分配不存在死锁检测死锁程序启动不存在死锁检测死锁程序启动进程4已挂起并且释放已占有资源进程3已挂起并且释放已占有资源进程1已挂起并且释放已占有资源进程O已挂起并且释放已占有资源产生死锁的进程为:012

14、34检测死锁程序启动进程4请求1个P3成功并且分配进程4请求3个P2失败进程4请求1个Pl成功并且分配进程0请求3个Pl成功并且分配运行自动检测与解除系统初始化完成进程2已挂起并且释放已占有资源选择自动检测运行,系统自然运行,没隔一段时间会自动检测是否会造成死锁。如果会造成死锁那么将会造成死锁的进程挂起,否那么不触发任何事件。5方案安排1.进度安排:寒假期间加深对该主题的了解、构思框架、分配任务、学习该掌握的内容并且完成局部功能。3月8日:确定界面3月9日-3月11:完善程序3月12日-3月13:修改缺乏,准备辩论2 .人员安排:* *:数据结构的构建、框架构建、界面设计、分配监督* *:银行

15、家算法设计及实现* *:死锁检测算法设计及实现3 .执行情况:我们小组各成员相互协作,都在规定的时间内完成了事先的方案,并将各自的模块有效地整合到一起,根本实现了题目要求的内容。6创新及特点1.界面设计直观、人性化,令用户容易入手该软件的使用。2 .每个进程的资源请求都为系统自动分配,实现一-键完成调度算法。3 .系统日志,系统自动显示出进程和资源的调度状态7存在问题及提高1 .整个系统的资源,及其资源请求都是固定的,可以进一步做到自定义。2 .死锁解除方案可以增加,以供选择。3 .日志复制,解读不够方便。4 .整体创新不够,可以往集群或者云计算方向考虑,但是难度较大。8实践总结小组:小组成员

16、都认真对待本次课程设计,小组成员配合良好。大家的思路开发、奇特,但由于技术问题限制了局部创新。各成员能够按时完成预先指定的任务甚至提前完成。提高了成员之间的协作能力,增加了同学们的友谊。*:通过这次实践,对于该主题的理论知识有了更加深入的了解,知道什么并发、死锁、如何预防死锁、如何防止死锁、何为银行家算法、平安性算法如何实现;协调小组成员的能力有所加强,明白如何与其他人沟通更有效率;应用软件的操作更加熟悉,并且有了更深一步的了解。*:通过这次课程设计,我加深了对于操作系统中对于死锁问题的理解,并意识到在团队合作工程中,作为一份子必须加强责任感、发扬吃苦耐劳的精神、增强开拓创新的意识不断加强理论

17、学习,拓展专业知识领域。*:经过了一个星期的课程设计,我想这对于自己以后的学习和工作都会有一定的帮助。在这次设计中遇到了一些实际性的问题,在实际设计中才发现,书本上理论性的东西与在实际运用中的还是有一定的出入的,所以有些问题不但要深入地理解,而且要不断地更正和改良以前的思维。很多问题必须要靠自己一点一滴的解决,而在解决的过程当中你会发现自己在步步的提升。虽然这次设计出来的东西很简单,也根底,但毕竟是一个理论联系实际的过程。更远一点可以联系到以后毕业之后从学校转到踏上社会的个过程。小组人员的配合、相处,以及自身的思考和努力,都是以后工作中需要的。参考文献1WilliamS.OperatingSystemsinternalsandDesignPrinciplesM.NewJersey:PrenticeHall,2003.2孙忠秀.操作系统教程.高等教育出版社,2008年,4月第四版:199.3王继奎,王会勇.基于银行家算法的进程平安序列全搜索算法.甘肃科学学报,2009年6月,第2期:152.4曹现玲.浅谈银行家算法.中国科技信息,2008年5月,第16期:127.5汤子瀛,哲凤屏,汤小丹.计算机操作系统.西安电子科技大学出版社.2002

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 在线阅读 > 生活休闲


备案号:宁ICP备20000045号-1

经营许可证:宁B2-20210002

宁公网安备 64010402000986号