- 1、本文档共25页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
操作系统PV操作习题补
1、用P.V操作解决下面的同步问题 2、重新研究司机和售票员问题,分别写出司机和售票员进程,从而实现该问题的同步 理发师问题: 一个理发店有一个入口和一个出口。 理发店内有一个可站5 位顾客的站席区、4 个单人沙发、3 个理发师及其专用理发工具、一个收银台。 新来的顾客坐在沙发上等待;没有空沙发时,可在站席区等待;站席区满时,只能在入口外等待。理发师可从事理发、收银和休息三种活动。 理发店的活动满足下列条件: 1)休息的理发师是坐地自己专用的理发椅上,不会占用顾客的沙发; 2)处理休息状态的理发师可为在沙发上等待时间最长的顾客理发; 3)理发时间长短由理发师决定; 4)在站席区等待时间最长的顾客可坐到空闲的理发上; 5)任何时刻最多只能有一个理发师在收银。 试用信号量机制或管程机制实现理发师进程和顾客进程。 。 原理: (1)customer 进程: 首先检查站席区是否已满(stand_capacity),若满选择离开,否则进入站席区,即进入理发店。在站席区等待沙发的空位(信号量sofa),如果沙发已满,则进入阻塞等待队列,直到出现空位,在站席区中等待时间最长的顾客离开站席区(stand_capacity)。坐到沙发上,等待理发椅(barber_chair),如果理发椅已满,则进入阻塞等待队列,直到出现空位,在沙发上等待时间最长的顾客离开沙发(释放信号量sofa)。坐到理发椅上,释放准备好的信号(customer_ready),获得该理发师的编号(0~1 的数字)。等待理发师理发结束(finished[barber_number])。在离开理发椅之前付款(payment),等待收据(receipt),离开理发椅(leave_barberchair)。最后离开理发店。 这里需要注意几点: a) 首先是几个需要进行互斥处理的地方,主要包括:进入站席区、进入沙发、进入理发椅和付款几个地方。 b) 通过barber_chair 保证一个理发椅上最多只有一名顾客。但这也不够,因为单凭baber_chair 无法保证一名顾客离开理发椅之前,另一位顾客不会坐到该理发椅上,因此增加信号量leave_barberchair,让顾客离开理发椅后,释放该信号,而理发师接收到该信号后才释放barber_chair 等待下一位顾客。 c) 在理发的过程中,需要保证是自己理发完毕,才能够进行下面的付款、离开理发椅的活动。这个机制是通过customer 进程获得给他理发的理发师编号来实现的,这样,当该编号的理发师释放对应的finished[i]信号的时候,该顾客才理发完毕。 d) 理发师是通过mutex 信号量保证他们每个人同时只进行一项操作(理发或者收款)。 e) 为了保证该顾客理发完毕后马上可以付款离开,就应该保证给该顾客理发的理发师在理 发完毕后马上到收银台进入收款操作而不是给下一位顾客服务。在伪码中由以下机制实现:即顾客在释放离开理发椅的信号前,发出付款的信号。这样该理发师得不到顾客的离开理发椅的信号,不能进入下一个循环为下一名顾客服务,而只能进入收款台的收款操作。直到顾客接到收据后,才释放离开理发椅的信号,离开理发椅,让理发师释放该理发椅的信号,让下一位等待的顾客坐到理发椅上。 (2)barber 进程 首先将该理发师的编号压入队列,供顾客提取。等待顾客坐到理发椅坐好(信号量customer_ready),开始理发,理发结束后释放结束信号(finished[i])。等待顾客离开理发椅(leave_barberchair)(期间去收银台进行收款活动),释放理发椅空闲信号(barber_chair),等待下一位顾客坐上来。 (3)cash(收银台)进程 等待顾客付款(payment),执行收款操作,收款操作结束,给付收据(receipt)。 信号量总表: 信号量 wait signal stand_capacity 顾客等待进入理发店 顾客离开站席区 sofa 顾客等待坐到沙发 顾客离开沙发 barber_chair 顾客等待空理发椅 理发师释放空理发椅 customer_ready 理发师等待,直到一个顾客坐到理发椅顾客坐到理发椅上,给理发师发出信号mutex 等待理发师空闲,执行理发或收款操作理发师执行理发或收款结束,进入空闲状态mutex1 执行入队或出队等待 入队或出队结束,释放信号finished[i] 顾客等待对应编号理发师理发结束;理发师理发结束,释放信号leave_barberchair 理发师等待顾客离开理发椅 顾客付款完毕得到收据,离开理发椅释放信号payment 收银员等待顾客付款 顾客付款,发出信号receipt
您可能关注的文档
- 小学语文四年级上册语文园地七.ppt
- 小数混合运算练习.ppt
- 小学语文四年级上册世界地图引出的发现课件2.ppt
- 小学数学简易方程.ppt
- 小班科学活动有趣的小风车.ppt
- 少先队科研的方法.ppt
- 就业信息的采集与处理求职材料制作(超实用包成功).ppt
- 小木虫emuch新药项目立项常用数据库.ppt
- 就业指导就业自荐.ppt
- 就业指导网上教程毕业生时间管理和求职准备.ppt
- 2025年甘肃省兰州市七里河区西湖街道社区卫生服务中心招聘编外工作人员笔试备考试题及答案解析.docx
- 2025四川自贡市中医医院招聘后勤岗位工作人员1人笔试模拟试题及答案解析.docx
- 2025云南西双版纳景洪市城市投资开发有限公司本部招聘2人笔试模拟试题及答案解析.docx
- 2025福建厦门市思明区部分单位联合招聘非在编工作人员44人考试笔试模拟试题及答案解析.docx
- 2025浙江丽水市市直招聘到村(社区)专职从事就业和社会保障2人笔试参考题库附答案解析.docx
- 2025广西大学教学型专任教师招聘3人笔试参考题库附答案解析.docx
- 2025四川广元市利州区东坝街道社区卫生服务中心招聘专业技术岗位编外人员4人笔试模拟试题及答案解析.docx
- 2025呼和浩特高速公路收费站及管理分中心招125人笔试模拟试题及答案解析.docx
- 2025丽水莲都区机关事业单位编外招聘26人笔试模拟试题及答案解析.docx
- 2025中央民族大学非事业编制合同制职工招聘1人(第二批)笔试模拟试题及答案解析.docx
文档评论(0)