进程同步练习题
更新时间:2023-12-09 07:32:01 阅读量: 教育文库 文档下载
进程同步练习题
1.第二类读者写者问题,信号量解决方法
2.复印室里有一个操作员为顾客复印资料,有5把椅子供顾客休息等待复印。如果没有顾客,则操作员休息。当顾客来到复印室时,如果有空椅子则坐下来,并唤醒复印操作员;如果没有空椅子则必须离开复印室。
3.如果有三个进程R、W1、W2共享一个缓冲器B,而B中每次只能存放一个数。当缓冲器中无数时,进程R可以将从输入设备上读入的数存放到缓冲器中。若存放到缓冲器中的是奇数,则允许进程W1将其取出打印;若存放到缓冲器中的是偶数,则允许进程W2将其取出打印。同时规定:进程R必须等缓冲区中的数被取出打印后才能再存放一个数;进程W1或W2对每次存入缓冲器的数只能打印一次;W1和W2都不能从空缓冲中取数。写出这三个并发进程能正确工作的程序。
4.现有四个进程R1、R2、W1、W2,它们共享可以存放一个数的缓冲器B。进程R1每次把来自键盘的一个数存入缓冲器B中,供进程W1打印输出;进程R2每次从磁盘上读一个数存放到缓冲器B中,供进程W2打印输出。为防止数据的丢失和重复打印,问怎样用信号量操作来协调这四个进程的并发执行。
5.有一个仓库,可以存放A和B两种产品,但要求: (1)每次只能存入一种产品(A或B);
(2)-N<A产品数量-B产品数量<M。其中,N和M是正整数。 试用同步算法描述产品A与产品B的入库过程。
6.设有两个生产者进程A、B和一个销售者进程C,他们共享一个无限大的仓库,生产者每次循环生产一个产品,然后入库供销售;销售者每次循环从仓库中取出一个产品进行销售。如果不允许同时入库,也不允许边入库边出库;而且要求生产和消费A产品和B产品的件数都满足以下关系:-n≤A的件数-B的件数≤m,其中n、m是正整数。
1. 第二类读者写者问题,信号量解决方法
答:为了使写者优先,可在原来的读优先算法的基础上增加一个互斥信号量s,初值为1,使得当至少有一个写者准备访问共享对象时,它可以使后续的读者进程等待完成; 整型变量writecount,初值为0,用来对写者进行计数;
互斥信号量mutex,初值为1,用来实现多个读者对写者writecount进行互斥访问。 Process reader() { while(1) {
wait(s); wait(rmutex);
if(readcount==0)wait(wmutex); readcount++; signal(rmutex); signal(s);
perform read operation;
wait(rmutex); readcount--;
if(readcount==0)signal(wmutex); signal(rmutex); } }
Process writer() { while(1) {
wait(mutex);
if(writecount==0)wait(s); writecount++; signal(mutex);
wait(wmutex);
perform write operation; signal(wmutex);
wait(mutex); writecount--;
if(writecount==0)signal(s); signal(mutex); } } Main( ) { cobegin { reader(); writer(); } }
2. 复印室里有一个操作员为顾客复印资料,有5把椅子供顾客休息等待复印。如果没有顾客,则操作员休息。当顾客来到复印室时,如果有空椅子则坐下来,并唤醒复印操作员;如果没有空椅子则必须离开复印室。
答: 信号量:
customers表示正在等待复印的顾客数量(不包括正在复印的顾客) operator记录正在等候顾客的操作员数,只有1和0 mutex用于对waiting的访问; 变量:
waiting表示等待的顾客数量。它实际上是customers的一个副本。之所以使用waiting是因为无法读取信号量的当前值。
semaphore customers=0,operator=0,mutex=1; waiting=0;
process operator( )//操作员进程 { while(1) {
wait(customers); //等待顾客到来 复印;
signal(operator); //通知顾客已经完成复印
} }
process cusotmeri( )//顾客进程i {
wait(mutex);
if(waiting<5) {
waiting++;
signal(customers); signal(mutex);
wait(operator);
wait(mutex); waiting--; signal(mutex); }
else {
signal(mutex); 离开复印室; } } main( ) {
cobegin { operator( ); customeri( ); } }
3、如果有三个进程R、W1、W2共享一个缓冲器B,而B中每次只能存放一个数。当缓冲器中无数时,进程R可以将从输入设备上读入的数存放到缓冲器中。若存放到缓冲器中的是奇数,则允许进程W1将其取出打印;若存放到缓冲器中的是偶数,则允许进程W2将其取出打印。同时规定:进程R必须等缓冲区中的数被取出打印后才能再存放一个数;进程W1或W2对每次存入缓冲器的数只能打印一次;W1和W2都不能从空缓冲中取数。写出这三个并发进程能正确工作的程序。
答:S为互斥信号量,用来对缓冲器的互斥使用;
SO和SE为资源信号量,SO表示是否允许进程W1打印;SE表示是否允许进程W2打印。 semaphore S=1,SO=SE=0; buffer B; process R() { int x;
while(1)
{从输入设备上读一个数; x=接收的数; wait(S); B=x;
if B=奇数 then signal(SO); else signal(SE); } } process W1() { int y; while(1) { wait(SO); y=B; signal(S); 打印y中数; }
}
process W2() { int z;
while(1) { wait(SE); z=B; signal(S); 打印z中数 ;
} } main() { cobegin
{
R(); W1(); W2();
}
}
4. 现有四个进程R1、R2、W1、W2,它们共享可以存放一个数的缓冲器B。进程R1每次把来
正在阅读:
进程同步练习题12-09
文献检索复习题及参考答案11-26
2016年6月英语六级真题写作范文3套09-20
实验问题10-26
高压电缆多用铝线原因08-13
化工管道端部连接方式及端部类型英文缩写11-08
土力学试题与答案前7章 205-01
干部推荐报告格式04-01
数据库原理及应用课后答案09-25
- exercise2
- 铅锌矿详查地质设计 - 图文
- 厨余垃圾、餐厨垃圾堆肥系统设计方案
- 陈明珠开题报告
- 化工原理精选例题
- 政府形象宣传册营销案例
- 小学一至三年级语文阅读专项练习题
- 2014.民诉 期末考试 复习题
- 巅峰智业 - 做好顶层设计对建设城市的重要意义
- (三起)冀教版三年级英语上册Unit4 Lesson24练习题及答案
- 2017年实心轮胎现状及发展趋势分析(目录)
- 基于GIS的农用地定级技术研究定稿
- 2017-2022年中国医疗保健市场调查与市场前景预测报告(目录) - 图文
- 作业
- OFDM技术仿真(MATLAB代码) - 图文
- Android工程师笔试题及答案
- 生命密码联合密码
- 空间地上权若干法律问题探究
- 江苏学业水平测试《机械基础》模拟试题
- 选课走班实施方案
- 练习题
- 进程
- 同步
- 立体有机
- 2018年华中农业大学硕士研究生招生调剂信息汇总
- 计量经济学题库(超完整版)及答案我整理的
- 领导干部基本情况登记表
- 护理学导论第四章测试题答案
- 儿子的鱼阅读答案文章结尾父亲说请问我儿子吧这是她的鱼
- 三年级24时计时法与普通计时法练习
- (湘美版)六年级美术下册教案 光影变幻 2
- 轴承本科毕业设计论文
- 会计学基础1
- 中国铸造煤粉行业市场前景分析预测年度报告(目录) - 图文
- 配套K12高二语文上学期期中考试试题(无答案)新人教版
- 高压电工理论题库7
- 2017年咨询工程师继续教育-有线通信
- 建筑结构抗震题库湖南城市学院
- 分析化学试题
- 数据库原理试卷
- 学校依法治校规章制度
- 案例:上海福克斯波罗有限公司
- 2013学年马原考试试题(两套)