- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
附件(四)
深 圳 大 学 实 验 报 告
课程名称: 操作系统
实验项目名称: 进程(线程)同步及死锁
学院: 计算机与软件学院
专业: 计算机科学与技术
指导教师:
报告人: 学号: 班级:
实验时间: 2015/10/23
实验报告提交时间: 2015/11/13
教务处制
一、实验目的与要求:
实验目的:
在多进程(线程)运行环境中,进程(线程)之间并发执行,如果对进程(线程)访问临界资源(如公共变量)的操作不加限制,就会产生“与时间有关”的错误。为防止这类错误,必须用同步机构控制进程(线程)对临界资源(公共变量)的访问。
在一个进程(线程)需要两个或两个以上的临界资源时,如果申请和推进顺序不当,会造成死锁,即多个进程(线程)因竞争临界资源而造成的一种僵局,若无力作用,这些进程(线程)都将永远不会再向前执行。
本实验利用Window系统提供的同步机制,来协调线程(Thread)间的并发执行,并比较各种预防死锁的措施,以加深对同步机制和死锁的理解,并学会在并发程序中引用同步机构,并预防死锁的编程方法。
实验要求:
熟悉Windows操作系统及VC程序设计方法。 二、方法、步骤:
设计解决哲学家就餐问题的并发线程。
假定有6个哲学家,围着圆桌交替地进行思考和进餐;每次进餐时,必须同时拿到左右两边的两只筷子才能进餐;进餐后,再放下筷子思考。
这是一个典型的同时需要两个资源的例子,如果申请资源顺序不当,可能会引起死锁。
本实验设计6个哲学家共享一个相同的线程Philosopher,既完成线程同步,又预防死锁发生。实验中采用了3种预防死锁的方法(摒弃‘环路等待’条件,摒弃‘请求和保持’条件,摒弃‘不剥夺’条件),要预防死锁,只采用其中的任何一种方法即可。
三.实验过程及内容:(其中:提供有简短说明的程序代码。要求:程序运行正确、符合设计要求。)
1.创建工程,注意勾选Win32 Application,点击确定
2.勾选第三个选项
3.创建菜单,有Eat、About、Exit
4.在进程(线程)同步及死锁.cpp中编写代码,此时代码有“摒弃‘环路等待’条件”、“摒弃‘请求和保持’条件”、“摒弃‘不剥夺’条件”三种代码,当检测其中一个时须将其余两个加以注释,一一检测其对死锁的影响。
运行结果:
运行前:
运行后:
5.在运行时可知,在分别“摒弃‘环路等待’条件”和“摒弃‘不剥夺’条件”的代码时不会出现死锁,而使用 “摒弃‘请求和保持’条件”时会产生死锁,在理论正确前提下,此种情况说明了代码出现错误。
6.代码解释及修改⑴摒弃‘环路等待’条件
R1=ThreadID;
R2=(ThreadID+1)%6;
if (ThreadID = = 0)
{
R1= (ThreadID+1) % 6;
R2= ThreadID;
}
依据摒弃‘环路等待’条件,要有至少一位哲学家与其他哲学家拿筷子顺序不同,则使第0位(ThreadID = 0)哲学家从右边开始拿筷子,其他哲学家相反。
⑵摒弃‘不剥夺’条件
Wait(Mutex);
if (ChopstickUsed[R2])
{
Signal(Mutex);
goto ReleaseChopstick;//将左筷子放弃掉
}
Signal(Mutex);
若分配给的哲学家拿不到右筷子,则将他拿到的左筷子收回。
⑶摒弃‘请求和保持’条件
原代码:
Wait(Mutex);
if((ChopstickUsed[R1])||(ChopstickUsed[R2]))
{
Signal(Mutex);
goto LoopAgain;//思考
}
Wait(ChopStick[R1]);//调用WaitForSingleObject等待信号量
DrawChopstick(hBrush[ThreadID],R1,TRUE);
Wait(ChopStick[R2]);
DrawChopstick(hBrush[ThreadID],R2,TRUE);
错误分析:此代码虽然if语句能够保证在左右筷子都没被其他线程申请并保持情况下进行拿筷子操作,但没有实现同时拿起筷子,
您可能关注的文档
- 践行三严三实,提高党性修养解析.doc
- 结构仿真(迈达斯)试验指导书解析.doc
- 践行三严三实加强党性修养和作风建设解析.doc
- 结构化检索决定安防平台未来解析.doc
- 结构化学【课后习题汇总】解析.doc
- 溅射镀膜操作流程解析.doc
- 结构件发展战略规划解析.doc
- 结构设计必备-材料篇解析.doc
- 江城区茶山中学申报市德育示范学校自评解析.doc
- 结构设计师培训解析.doc
- 2025年文化旅游演艺项目策划与文化旅游目的地品牌推广报告.docx
- 教育信息化2.0时代教师继续教育创新模式研究报告.docx
- 2025年汽车共享平台智能出行服务与市场竞争力分析报告.docx
- 工业互联网平台区块链智能合约安全防护策略与实施路径研究报告.docx
- 2025年电商行业直播电商与品牌合作模式研究报告.docx
- 法律本质特征与运行环节知识测试卷.docx
- 2025年土壤改良剂在农业面源污染控制中的应用研究报告.docx
- 基层医疗卫生机构信息化建设中的医疗信息化技术应用与市场前景预测报告.docx
- 核舟记简答题题目及答案.doc
- 2025年建筑施工安全管理信息化在施工现场安全信息管理中的应用报告.docx
文档评论(0)