版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、 课程实验报告 题 目 计算机操作系统理发师问题 姓 名 潘 * 学 号 2013 * 年级专业 2013级* 指导教师 彭 * 华 201*年 1*月 30 日一 题目假设有个理发店,只有一个理发师和N张可供顾客等待理发的椅子,如果没有顾客,则理发师睡觉,如果有一个顾客进入理发店发现理发师在睡觉,则把他叫醒,试用信号量设计一个协调理发师和顾客的程序。二 PV操作伪代码C语言的伪代码实现:int waiting=0 ; /等候理发的顾客数 int chairs=n; /为顾客准备的椅子数 semaphore customers=0,&
2、#160;barbers=0,mutex=1; barber() while(TRUE); /理完一人,还有顾客吗? P(cutomers); /若无顾客,理发师睡眠 P(mutex); /进程互斥 waiting -= 1;/等候顾客数少一个 V(barbers); /理发师去为一个顾客理发 V(mutex); /开放临界区 cut-hair(); /正在理发 customer() P(mutex
3、); /进程互斥 if(waiting) waiting += 1; / 等候顾客数加1 V(customers); /必要的话唤醒理发师 V(mutex); /开放临界区 P(barbers); /无理发师, 顾客坐着养神 get-haircut( ); /一个顾客坐下等理/ else V(mutex); /人满了,离开 三 程序流程图顾客模块:理发师模块:四 源程序的实现因为本人对C+的多线程库函数不了解,于是使用JAVA实现理
4、发师问题,假设有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(Stri
5、ng 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;pub
6、lic 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.
7、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(&qu
8、ot;现在理发店只有顾客" + 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.p
9、rintln("没有顾客了,理发师开始睡觉");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.printStackTr
10、ace();五 运行结果顾客 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、顾客 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 离开了顾
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026年人力资源师管理实务专项训练卷(附答案)
- 初三道德与法治中考一轮复习:易错易混核心知识辨析与素养提升教案
- 初中八年级历史上册(部编版)核心知识清单:戊戌变法
- 2026年食品工艺学专业知识真题含答案
- 板蓝根(Isatidis Radix)种植产业高质量发展与全球竞争力构建战略研究(年)行业报告
- 北师大版小学数学三年级寒假作业第一周教学设计
- 城市公共安全治理:烟花爆竹“打非”专项行动策略与实务(应急管理专业高职二年级核心技能课教案)
- 室内给水管道施工方案
- 项目部应急医疗救护措施
- 医疗质量与安全管理知识考核试题及答案
- hiv职业暴露培训课件
- 建筑垃圾处理技术标准(CJJT 134-2019)
- 黑龙江省齐齐哈尔市2024年中考数学试卷含真题解析
- 人教版(2025)七年级下册地理教材活动题答案
- 2025-2030年中国铝合金船舶行业深度研究分析报告
- 2025年永州市江永县三支一扶招募高校毕业生招聘高频重点提升(共500题)附带答案详解
- 《如何建立客户信任》课件
- 《策略九问》决定复杂销售成败的九大思考
- 《妊娠剧吐》课件
- 《中级财务会计(一)》期末机考资料
- 北京人朝初一分班考英语试题及答案
评论
0/150
提交评论