操作系统实验五理发师问题.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
操作系统实验五理发师问题

实验题目:理发师问问题 学号:201000130133 班级: 2010级计算机4班 姓名: 郑思雨 Email:1412561943@ 实验目的:1、进一步研究和实践操作系统中关于并发进程同步与互斥操作的一些经典问题的解法。 2、加深对于非对称性互斥问题有关概念的理解。观察和体验非对称性互斥问题的并发控制方法。 3、进一步了解Linux系统中IPC进程同步工具的用法,训练解决对该类问题的实际编程、调试和分析问题的能力。 硬件环境:? 微机(多核,4GB 以上内存,320GB 以上硬盘) 软件环境: Ubuntu-Linux 操作系统 Gnome 桌面 gcc version 4.1.2 gedit 2.18.2 OpenOffice 2.3 实验步骤: 1、了解实验的目的,了解并掌握与进程间通信IPC中的3个对象:共享内存、信号灯数组、消息队列到呢个有关的系统调用,并能熟练的掌握。 2、阅读实验题目并分析实验的需求。 理发店问题:假设理发店的理发室中有3个理发椅子和3个理发师,有一个可容纳4个顾客坐等理发的沙发。此外还有一间等候室,可容纳13位顾客等候进入理发室。顾客如果发现理发店中顾客已满(超过20人),就不进入理发店。 在理发店内,理发师一旦有空就为坐在沙发上等待时间最长的顾客理发,同时空出的沙发让在等候室中等待时间最长的的顾客就坐。顾客理完发后,可向任何一位理发师付款。但理发店只有一本现金登记册,在任一时刻只能记录一个顾客的付款。理发师在没有顾客的时候就坐在理发椅子上睡眠。理发师的时间就用在理发、收款、睡眠上。 首先创建ipc.h文件,在里面定义生产者/消费者共用的IPC函数的原型和变量。 然后创建ipc.c文件,在里面定义生产者/消费者共用的IPC的具体的相应函数。 创建sofa_control文件,在里面声明两个消息队列,当沙发空闲时则会将空闲的消息放入相应的队列中,让顾客可以进入沙发中,当理发师空闲时,也会将相应的消息放入队列中,从而可以让顾客到理发椅上进行理发。 创建room_control文件,在里面创建消息队列,当等待室里的人数少于十三个时,若从消息队列中获得信息,则顾客可以进入,当沙发上有空位时,在等待室的人可以进入沙发等待。 创建customer文件,里面声明两个消息队列,当获得允许进入的信息时,顾客进入等待室,当顾客理完发则会离开,同时向消息队列中发送信息。 创建barber文件,在里面声明三个队列,当理发师就绪则会向队列中发送消息,若顾客收到消息就会去理发,当顾客离开时,也会想队列中发送一条消息。同时理发师理发与收账是互斥的。通过上述的文件就可以实现相应的功能。 3、分析清楚实验要求,便开始用编程语言进行编程,将分析的思路用编程语言实现。 4、 完成编写程序,要进行运行调试,找到编写中的错误,进行进一步的修改,直到程序运行过程中不再出现错误. 5、 完成程序的调试与修改,保存程序,对编程的过程进行总结,找到编程中的不足,并完成实验报告 结论分析与体会: 结论:利用 IPC机制中的消息队列来实现相应的功能。通过往队列 中放入信 和从队列中获取信息来实现进程间的通信,当顾客少于三个时,理 师可以接给顾客理发并收取费用;当顾客多于三个少于七个时顾客要 在沙发等待,理发师给顾客理完发然后等待簿进行记账;当顾客多于 七个时,四个顾客在沙发上等,其他的在等待室等待,直到沙发空出 才能从等待室到沙发,然后每给一个顾客理完发,则理发师等待账簿 进行记账。通过建立多个消息队列就可以实 现相应的功能。 体会:1、通过实验对进程同步与互斥概念有了更深入的了解,加深了解了进程同步与互斥的效果。 2、加深了对非对称性互斥问题有关概念的理解,并进一步掌握了对经典 问题的解法。 3、进一步熟练掌握了进程间通信有关的系统调用,并学会用它们进行编程和调试。 4、通过实验对相应的知识有了深入的理解,对编程软件也更熟练的掌握。 代码实现如下: ipc.c代码部分: #include ipc.h /* * get_ipc_id() 从/proc/sysvipc/文件系统中获取 IPC 的 id 号 * pfile: 对应/proc/sysvipc/目录中的 IPC 文件分别为 * msg-消息队列,sem-信号量,shm-共享内存 * key: 对应要获取的 IPC 的 id 号的键值 */ int get_ipc_id(char *proc_file,key_t key) { FILE *pf; int i,j; char line[BUFSZ],colum[BUFSZ]; if((pf = fopen

文档评论(0)

almm118 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档