例题以及习题pv操作3.docx

例题以及习题pv操作3.docx

ID:60368647

大小:15.61 KB

页数:4页

时间:2020-12-05

例题以及习题pv操作3.docx_第1页
例题以及习题pv操作3.docx_第2页
例题以及习题pv操作3.docx_第3页
例题以及习题pv操作3.docx_第4页
资源描述:

《例题以及习题pv操作3.docx》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、【实战3】理发师问题理发店有一位理发师、一把理发椅及三把供等候理发的顾客坐的椅子。如果没有顾客,理发师就去睡觉。如果顾客来时所有的椅子都有人,那么顾客就离去。如果理发师在忙而有空闲的椅子,那么顾客就会坐在其中的一个空闲的椅子上。如果理发师在睡觉,顾客会唤醒他。请利用信号量(semaphores),写个程序来协调理发师和顾客进程。【浙江大学2007】intcount=0;//记录理发店里的顾客数量semaphoremutex=1;//用于互斥访问count变量所用的信号量semaphorebarbe

2、r_chair=0;//semaphorewait_chair=3;//顾客等待时可坐的椅子semaphoreready=0;//坐在等候椅子上等待理发的顾客数量Barber(){//理发师进程while(1){wait(ready);//是否有顾客在等待理发,没有则阻塞signal(barber_chair);//请等待时间最长的顾客坐到理发椅上signal(wait_chair);//坐到理发椅上的顾客让出一个等待时可坐的椅子barbering//给顾客理发}}Customer(){//顾客进

3、程i{wait(mutex);if(count>=4){//如果理发店已经有四个顾客了signal(mutex);leave//走人}else{//理发店里顾客不足4个count++;//更新顾客人数signal(mutex);1}wait(wait_chair);//先请求坐等待时坐的椅子signal(ready);//告诉理发师又有一位顾客准好了,等待理发wait(barber_chair);//再请求坐理发椅bebarberedwait(mutex);count--;//更新店里的顾客人数s

4、ignal(mutex);}}2【练习1】如图所示,有多个PUT操作同时向BUFF1放数据,有一个MOVE操作不断地将BUFF1的数据移到BUFF2,有多个GET操作不断地从BUFF2中将数据取走。BUFF1的容量为m,BUFF2的容量是n,PUT、MOVE、GET每次操作一个数据,在操作的过程中要保证数据不丢失。试用P、V原语协调PUT、MOVE的操作,并说明每个信号量的含义和初值。PUTMOVEGETBuff1Buff2进程操作图【分析】这里存在两个一般意义的“生产者—消费者”问题,PUT(生

5、产者)与MOVE(消费者)之间,需要设置三个信号量;MOVE(生产者)与GET(消费者)之间,需要设置三个信号量。PUT进程套用生产者进程即可,MOVE进程只有在Buff1有新数据且Buff2有空闲区的时候才移动数据,GET进程套用消费者进程即可。答案:设置6个信号量full1、empty1、B-M1、full2、empty2、B-M2,它们的含义和初值如下:1)full1表示Buff1是否有数据,初值为0;2)empty1表示Buff1有空间,初值为m;3)B-M1表示Buff1是否可操作,初值

6、为1;4)Full2表示Buff2是否有数据,初值为0;5)Empty2表示Buff2有空间,初值为n;6)B-M2表示Buff2是否可操作,初值为1;{repeatP(empty1);/*判断Buff1是否有空间,没有则等待*/P(B-M1);/*是否可操作Buff1*/PUT;V(B-M1);/*设置Buff1可操作标志*/V(full1);/*设置Buff1有数据的标志*/untilfalse}{repeatP(full1);/*判断Buff1是否有数据,没

7、有则等待*/P(empty2);/*判断Buff2是否有空间,没有则等待*/P(B-M1);/*是否可操作Buff1*/P(B-M2);/*是否可操作Buff2*/MOVE;V(B-M1);/*设置Buff1可操作标志*/V(B-M2);/*设置Buff2可操作标志*/3V(empty1);/*设置Buff1有空间标志*/V(full2);/*设置Buff2有数据标志*/untilfalse}{repeatP(full2);/*判断Buff2是否有数据,没有则等待*/P(B-M2)

8、;/*是否可操作Buff2*/GET;V(B-M2);/*设置Buff2可操作标志*/V(empty2);/*设置Buff2有空间的标志*/untilfalse4

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。