




已阅读5页,还剩3页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
课程实验报告 题 目 计算机操作系统理发师问题 姓 名 潘 * 学 号 2013 * 年级专业 2013级* 指导教师 彭 * 华 201*年 1*月 30 日一 题目假设有个理发店,只有一个理发师和N张可供顾客等待理发的椅子,如果没有顾客,则理发师睡觉,如果有一个顾客进入理发店发现理发师在睡觉,则把他叫醒,试用信号量设计一个协调理发师和顾客的程序。二 PV操作伪代码C语言的伪代码实现:intwaiting=0;/等候理发的顾客数 intchairs=n;/为顾客准备的椅子数 semaphorecustomers=0,barbers=0,mutex=1; barber() while(TRUE);/理完一人,还有顾客吗? P(cutomers);/若无顾客,理发师睡眠 P(mutex);/进程互斥 waiting-=1;/等候顾客数少一个 V(barbers);/理发师去为一个顾客理发 V(mutex);/开放临界区 cut-hair();/正在理发customer() P(mutex);/进程互斥 if(waiting) waiting+=1;/等候顾客数加1 V(customers);/必要的话唤醒理发师 V(mutex);/开放临界区 P(barbers);/无理发师,顾客坐着养神 get-haircut();/一个顾客坐下等理/ elseV(mutex);/人满了,离开三 程序流程图顾客模块:理发师模块:四 源程序的实现因为本人对C+的多线程库函数不了解,于是使用JAVA实现理发师问题,假设有5张可供顾客理发的椅子:package com.swxy;import java.util.concurrent.Semaphore;/导入Semaphore,用于控制进程同步互斥的量。public class BarberShop static int cnt = 0;/ 顾客static int MAX = 5;/ 假设5张可供顾客理发的椅子static int busy = 0;static Semaphore mutex = new Semaphore(1);/ 临界区互斥访问信号量(二进制信号量),相当于互斥锁。public static void main(String args) throws InterruptedException BarberShop bar = new BarberShop();for (int i = 1; i = 20; i+) / 假设一共有20个顾客来访new Thread(new Barber(bar, i).start();Thread.sleep(int) (400 - Math.random() * 300);/ 使得当前线程休眠 随机0-0.1spublic synchronized boolean isFull() if (cnt = MAX) return true;return false;public synchronized boolean isEmpty() if (cnt = 0) return true;return false;public synchronized boolean isBusy() if (busy = 1) return true;return false;public void Gobar(int index) throws InterruptedException System.out.println(顾客 + index + 来了);cnt+;/ 判断是否满if (isFull() System.out.println(没有可供顾客等待的椅子了, + 顾客 + index + 离开了);cnt-; else if (busy = 1) System.out.println(顾客 + index + 正在等待理发师);mutex.acquire();/ 信号量减操作,防止其他进程再进入synchronized (this) while (busy = 1) / 若有人在理发,则等待wait();if (cnt = 1) System.out.println(现在理发店只有顾客 + index + ,理发师是清醒的);busy = 1;System.out.println(顾客 + index + 正在理发);Thread.sleep(1000);System.out.println(顾客 + index + 离开了);cnt-;mutex.release();/ 信号量加操作synchronized (this) busy = 0;notify();/ 唤醒if (cnt = 0) System.out.println(没有顾客了,理发师开始睡觉);class Barber implements Runnable BarberShop ob;int index;public Barber(BarberShop ob, int i) this.ob = ob;index = i;public void run() / TODO Auto-generated method stubtry ob.Gobar(index); catch (InterruptedException e) / TODO Auto-generated catch blocke.printStackTrace();五 运行结果顾客 1 来了现在理发店只有顾客1,理发师是清醒的顾客1 正在理发顾客 2 来了顾客2 正在等待理发师顾客 3 来了顾客3 正在等待理发师顾客 4 来了顾客4 正在等待理发师顾客1 离开了顾客2 正在理发顾客 5 来了顾客5 正在等待理发师顾客 6 来了没有可供顾客等待的椅子了,顾客 6 离开了顾客 7 来了没有可供顾客等待的椅子了,顾客 7 离开了顾客 8 来了没有可供顾客等待的椅子了,顾客 8 离开了顾客2 离开了顾客3 正在理发顾客 9 来了顾客9 正在等待理发师顾客 10 来了没有可供顾客等待的椅子了,顾客 10 离开了顾客 11 来了没有可供顾客等待的椅子了,顾客 11 离开了顾客3 离开了顾客4 正在理发顾客 12 来了顾客12 正在等待理发师顾客 13 来了没有可供顾客等待的椅子了,顾客 13 离开了顾客 14 来了没有可供顾客等待的椅子了,顾客 14 离开了顾客 15 来了没有可供顾客等待的椅子了,顾客 15 离开了顾客4 离开了顾客5 正在理发顾客 16 来了顾客16 正在等待理发师顾客 17 来了没有可供顾客等待的椅子了,顾客 17 离开了顾客 18 来了没有可供顾客等待的椅子了,顾客 18 离开了顾客 19 来了没有可供顾客等待的椅子了,顾客 19 离开了顾客5 离开了顾客9 正在理发顾客 20 来了顾客20 正在等待理发师顾客9 离开了顾客12 正在理发顾客12 离开了顾客16 正在理发顾客16 离开了现在理发店
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 离婚协议书子女抚养权及财产分割及子女生活费用合同
- 车辆质押贷款担保责任及风险控制协议范本
- 科技园区停车位出售与科技创新服务协议
- 论文教学设计教学课件
- 2025至2030无线点菜收银系统行业发展趋势分析与未来投资战略咨询研究报告
- 保险业服务实体经济质效的策略及实施路径
- 2025至2030中国天然护肤行业发展趋势分析与未来投资战略咨询研究报告
- 2025至2030中国味噌行业产业运行态势及投资规划深度研究报告
- 2025至2030中国原纸行业市场占有率及投资前景评估规划报告
- 2025至2030中国卫生纸行业产业运行态势及投资规划深度研究报告
- 2025年高考真题-政治(黑吉辽卷) 含答案(黑龙江、吉林、辽宁、内蒙古)
- T/QX 004-2020工业清洗作业人员呼吸防护用品选择、管理、使用和维护指南
- 河北省石家庄市2025年七年级下学期语文期末考试卷及答案
- 四川省德阳市2025年七年级下学期语文期末试卷及答案
- 石狮子购销合同协议
- 2025广州市荔湾区辅警考试试卷真题
- 课题申报书:基于核心素养发展理念的小学数学跨学科主题学习设计的策略研究
- 模联面试题及答案
- 上海市杨浦区2025届高三语文一模质量调研试卷(含答案)
- 隔壁拆房相邻协议书
- GB/T 320-2025工业用合成盐酸
评论
0/150
提交评论