版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、目录1 设计题目与要求2设计目的设计要求2 总体设计思想与相关知识2总体设计思想问题描述解决方案3 数据结构、流程图2数据结构流程图4 . 源代码.35 运行结果.66 结果分析.77 总结及心得体会.7设计题目与要求设计目的掌握进程同步问题的解决思路及方法,熟练使用Windows操作系统提供的信号量机制解决各种 进程同步问题。设计要求设有五个哲学家,共用一张放有五把椅子的餐桌,每人坐在一把椅子上,桌子上有五个碗和五只筷 子,每人两边各放一只筷子。哲学家们是交替思考和进餐,饥饿时便试图取其左右最靠近他的筷子。条 件:(1) 只有拿到两只筷子时,哲学家才能吃饭。(2) 如果筷子已被别人拿走,则必
2、须等别人吃完之后才能拿到筷子。(3) 任意一个哲学家在自己未拿到两只筷子吃饭前,不会放下手中拿到的筷子。2总体设计思想与相关知识总体设计思想哲学家的生活就是思考和吃饭,即思考,饿了就餐,再思考,循环往复。要求是:每一个哲学家 只有在拿到位于他左右的筷子后,才能够就餐;哲学家只能先拿左边的筷子,再去拿右边的筷子,而 不能同时去抓他两边的筷子,也不能从其他哲学家手中抢夺筷子;哲学家每次就餐后必须放下他手中 的两把筷子后恢复思考,不能强抓住餐具不放。设计一个程序,能够显示当前各哲学家的状态和桌上餐具的使用情况,并能无死锁的推算出下一 状态各哲学家的状态和桌上餐具的使用情况。即设计一个能安排哲学家正常
3、生活的程序。问题扌苗述 可能出现死锁问题,因为当五个哲学家都饥饿时,都拿着一支筷子,这样就可能五个哲学家都用不上餐。解决方案最多允许4个哲学家同时坐在桌子周围。给所有哲学家编号,奇数号的哲学家必须首先拿左边的筷子,偶数号的哲学家则反之。为了避免死锁,把哲学家分为三种状态,思考,饥饿,进食,仅当一个哲学家左右两边的筷子 都可用时,才允许他拿筷子,并且一次拿到两只筷子,否则不拿。3 .数据纟吉构及流程图 数据结构philosopherProc+myid:int+mystate:int+philosopherProc(LPVOIDIpParameter)+ ResumeThread(hPhiloso
4、pheri):int+strcpy(stateStr, ):int程序中定义一个哲学家类,包含两个私有对象和四个公有对象。myid对象:报讯哲学家的编号。mystate对象:用于保存当前该哲学家的状态, philosopherProc( LPVOID IpParameter)方法:哲学家类构造函数,PHILOSOPHER_NUM 表示哲学家 编号ResumeThread(hPhilosopheri)方法:返回该哲学家编号strcpy(stateStr,)方法:返回哲学家当前状 态根据题目要求改变哲学家的状态(饥饿- 进餐-思考-饥饿)流程图4源代码(C+). endl;Rele aseMute
5、x(mutex);初始状态为改变状态先检查左筷子是否左筷子可用就拿起,右筷子可用,就改如果右筷子不可改变自己的状态mystate = THINKING;/THINKINGleftFork 二(myid) % PHILOSOPHER.NUM; rightFork二(myid + 1) % PHILOSOPHER_NUM;while (true)switch(mystate)case THINKING:mystate = HUNGRY;/strcpy(stateStr, HUNGRY);break;case HUNGRY:strcpy(stateStr, HUNGRY);ret 二 WaitFor
6、SingleObject(semaphoreleftFork, 0); 可用if (ret 二二 WAIT_OBJECT_0)ret 二 WaitForSingleObjecsemaphorefrightFork, 0); / 再检 查右筷子是否可用if (ret 二二 WAIT_OBJECT_0)mystate二DINING; /变自己的状态strcpy(stateStr, DINING1);elseReleaseSemaphore(seiriaphoreleftForkJ 1, NULL); / 用, 就把左筷子放下break;case DINING:/吃完后把两支筷子都放下Release
7、Semaphore(semaphore卩eftFork, 1, NULL);ReleaseSemaphore(semaphorerightForkJ 1, NULL);mystate 二 THINKING; / strcpy(stateStr, THINKING);break;输出状态WaitForSingleObject(mutex, INFINITE);cout philosopher myid is: stateStr endl; ReleaseMutex(mutex);/ sleep a random time : between 1 - 5 sint sleepTime;sleepT
8、ime 二 1 + (int)*rand()/(RAND_MAX+);Sleep(sleepTime*10);int main()int i;srand(time(O);mutex 二 C re a te M u tex( N U L L, false, NULL);for(i=0; iPHILOSOPHER_NUM; i +)semaphore二 CreateSemaphore(NULL, 1, 1, NULL);hPhilosopheri=CreateThread(NULL,0,philosopherProc 丄PVOID(i), CREATE_SUSPENDED,O);for(i=0;
9、iPHILOSOPHER_NUM; i +)ResumeThread(hPhilosopheri);Sleep(2000);return 0;5 运行结果IPhilOSOPherObeginPhilOSOPher1 begin.PhilOSOPher2 begin.philosopher3 begin.PhilOSOPher4 begin.PhilOSOPher0 is :HUNGBYPhilOSOPher1 is:HUNGRyPhilOSOPheF2 is :HUNGRYPhilOSOPheF3 is:HUNGKYPhilOSOPher4 is :HUNGRYPhilOSOPheF0 is
10、:l)ININGPhilOSOPheV1 is :HUNGRYPhilOSOPher2 is:PININGPhilOSOPyleF3 is:HUNGBYPhilOSOPhep4 is :HUNGRyPhilnsnpkAVaTilTNKTNCPhilOSoPheF1 is:HUNGPVphilosopher2 is:THINKINGPbilOSOPhev0 is!HUNGRyphilosopher3 IS =DININGphilosopher1 is :BININGPhilOSOpbei*4 is /HUNGBVphilosopher2 is:HUNGPyPhilOSO phei*3 is:TH
11、INKINGphilosopher4 is :DININGPhilOSO pbei*0 is :HUNCBVPhilOSOPber1 is:THINKINGphilosopher2 is三DININGPbilOSOPber3 is :HUNGRYPbilOSOPber0 is三HUNGRYPhilOSOPher4 is :THINKIHGPhilOSOPher1 is:HUNGBYPhilOSOPher2 is:THINKINGPhilOSOPher3 is:l)ININGPhilOSOPher0 is :DININGPbilOSOPbCr4 is IIUNGnVPhilOSOPher1 is
12、:HUNGBYPhilOSOPher2 is :HUNGBYPhilOSOPher0 is :THINKINGPhilOSOPheF3 is:THINKINGPhilOSOPheF1 is:DININGPhilOSOPher4 is :BININGPhilOSOPheF2 is :HUNGBYPhilOSOPheV3 is:HUNGBYPhilOSOpFier4 is :THINKINGPhilOSOPhep0 is :HUNGBYPhilOSOPheF1 is :THINKINGPhilOSOPheF2 is:BININGPhilOSoPher3 is:HUNGpVphilosopher4
13、is :HUNGHYPhiLOSOPheP 0 isDININGPhLIOSOPheP 1 LSHUNGRVphilosopher 2 isTHINKINGPhilOSOPheP 3 isDININGphilosopher 0 is :THINKINGPhiLOSOPheP4isHUNGRYphilosopher 1 isDININGPhilOSOPheP 0 isHUNGRYPhilOSOPh 2 isHUNGRVPhilOSOPheP 1 isTHINKINGphilosopher 3 isTHINKINGphilosopher 2 i.sDININGPhilOSOPiei 4 isDIN
14、INGphilosopher 3 isHUNGRYPhilOSOPhei4isTHINKINGPhilOSoPher 0 ISDININGPhilOSOPhe i* 1 ISHUNGRVPhllOSOPhei2 ISTHINKINGPhXIOSOPhei 3 XSDININGPhilOsopjiei* 0 isTHINKINGPhiloSOPJIer4 isHUNGRVphilosopher 1 isDINIHGPhiloSOPher 2 isHUHGRVPhilOSOPher 3 isTHINKINGPhilOSOPher 0 isHUHGRVphilosopher 1 isTHINKING
15、PhilOSOPher4 isDININGPhilOSOPher 2 LSDININGPhilOSOPher & isHUNGRVPhiLOSOPher3 isHUNGRVPhilOSOPher 1 isHUNGRYPhilOSOPher SisHUhl GRVPhilOSOPher 2isIHINKINGPhilOSOPher 4 isTHINKINGPhilOSOPher 1 isDININGPhLIOSODheP 3 isDININGPhilOSOPheP 0 isHUNGRVPhilOSOPheP 2isHUNGRYPhilOSOPheP 1 isTHINKINGphilosopher
16、 3 LSTHINKINGphilosopher 4 isHUNGRVPhilOSOPhep 2 isDININGPhilOSOPheP p isDININGPhiLOSOPhep3isHUNGRVPhilOSOPhep 1 isHUNGRVPhiLOSOPheH 4 isHUNGRYPhilOSOPheP 9 isTHINKINGPhilOSOPhep 2isTHINKINGPhilOSOPheP 1 is:DININGPhiLOSOPh&p 3 is:DINING6结果分析对哲学家进行编号,将他们的初始状态全部设定为THINGKING,接着先从0开始改变他们的 状态为HUNGR, 丫继续运行后4号和2号哲
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 医院感染管理护士工作创新案例
- 扶贫项目专员助理项目数据分析报告
- 国企与民企招聘面试技巧指南
- 印度咖喱与香料使用指南
- 学校面试流程详解与模拟实战训练
- 可靠性设计工程师工程案例分析
- 政务值班岗应急响应预案
- 南宁期货市场交易者的心理调适与压力管理
- 地铁规划与设计技能考核
- 大学生参加学术竞赛面试策略
- 高血压病病人护理
- 老年骨折病人的术后护理
- 幼儿园食堂从业人员晨检制度
- 超星尔雅学习通《学术规范与学术伦理(华东师范大学)》2025章节测试附答案
- 第14课 丝绸之路的开通与经营西域(教学设计)2024-2025学年七年级历史上册同步高效课堂(统编版2024)
- 卫生室废弃药品管理制度
- DB11-T 1034.2-2013 交通噪声污染缓解工程技术规范 第2部分 声屏障措施
- 微项目3《计算生成新的数据》说课稿-2024-2025学年泰山版(2019)初中信息技术第三册(八年级上)
- 2025年湖北宜昌市宜都市高新技术产业投资有限公司招聘笔试参考题库附带答案详解
- DB33T 1215-2020 城市轨道交通轨道工程施工质量验收标准
- 锅炉设备维护保养方案
评论
0/150
提交评论