已阅读5页,还剩13页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
2.4 经典进程的同步问题,在多道程序环境下,进程同步问题十分重要,出现一系列经典的进程同步问题,常被用于研究、设计与评价一个同步机制,同时为解决新的并发程序设计问题提供了重要的参考,其中代表性有: 生产者消费者问题 读者写者问题 哲学家进餐问题,作 业,1、问题描述,描述了一组生产者向一组消费者提供产品,它们共享一个有界缓冲池,池中有n缓冲区,生产者向其中投放产品,消费者从中取得产品消费。 如图所示。,P1 P2 pm,C1 C2 Cn,生产者,消费者,产品,有界缓冲池,某个生产者进程生产产品并放入缓冲区, 生产一个产品 申请一个可放产品的空缓冲区 申请临界资源(有界缓冲池)的使用 放产品到指定缓冲区 释放临界资源(有界缓冲池)的使用 释放一个装有产品的缓冲区 ,某个某个消费者进程消费从缓冲区取产品并消费, 申请一个装有产品的缓冲区 申请临界资源(有界缓冲池)的使用 从指定缓冲区取出产品 释放临界资源(有界缓冲池)的使用 释放一个空缓冲区 消费此产品 ,所需信号量、物理意义及初值 两个同步信号量: empty:表示空缓冲区的数目,其初值为有界缓冲区的大小n。 Full: 表示装有产品的缓冲区数目(即产品数),初值为0. 互斥信号量: Mutex: 表示互斥使用该有界缓冲池这一临界资源,初值为1。 semaphore full=0; /*表示满缓冲区的数目*/ semaphore empty=n; /*表示空缓冲区的数目*/ semaphore mutex=1; /*表示对有界缓冲池进行互斥操作*/, 生产一个产品; wait(empty); wait(mutex); 将一个产品送入缓冲区; signal(mutex); signal(full); ,Producer(i), wait(full); wait(mutex); 从缓冲区取走一个产品; signal(mutex); signal(empty); 消费一个产品; ,consumer(j),注意事项,1. 在进程的同步与互斥问题中, P,V操作必须成对出现,有一个P操作就一定有一个V操作。当为互斥操作时,它们同处于同一进程;当为同步操作时,则一定不在同一进程中出现。 思考:在生产者-消费者问题中,如果缺少了V(full)或V(empty),对执行结果将会有何影响?,“生产者-消费者”问题中应注意,2.任意一对相邻的P操作顺序非常重要。在并发环境中,当进程既要同步又要互斥时,必须把互斥信号量的P操作放在同步信号量的P操作之后, 否则会引起进程死锁.而两个V操作的顺序则无关紧要。 思考:在生产者-消费者问题中,如果将两个P操作即P(empty)和P(mutex) 互换位置,或者将两个V操作即V(mutex)和V(full)互换位置,结果会如何?,“生产者-消费者”问题中应注意,3.生产者-消费者问题是操作系统和现实生活中许多相互合作进程的一个抽象模型。 思考:p69,28题,返回,2、“读者写者”问题,问题描述: 一个数据对象(数据文件或记录)可被多个进程共享。其中,reader进程要求读,writer 进程要求写或修改。允许多个reader进程同时读共享数据,但绝不允许一个writer进程与其它的reader进程或writer进程同时访问,即writer进程必须与其它进程互斥访问共享对象。,某个读进程读数据, 申请修改计数变量Readcount 若为首位(Readcount=0)读进程,申请对数据对象的读权(与写进程互斥) 修改计数变量Readcount(加1) 释放计数变量Readcount的使用 读数据对象 申请修改读进程计数变量Readcount(临界资源) 修改计数变量Readcount(减1) 若为末位(Readcount=0)读进程,释放对数据对象的读权(与写进程互斥) 释放临界资源(计数变量Readcount)的使用 , 申请对数据对象的写权(与读写进程互斥) 写数据 释放对数据对象的写权(与读写进程互斥) ,某个写进程写数据,计数变量Readcount:记录当前正在读数据的读进程数目, 读互斥信号量Rmutex :表示读进程互斥地访问计数变量 readcount,初值为1. 写互斥信号量wmutex:表示写进程与其它进程(读、写) 互斥地访问数据,初值为1. semaphore Rmutex=1; semaphore wmutex=1; int readcount=0;,设置一个共享变量和两个信号量,某个读进程读数据, 申请修改计数变量Readcount 若为首位(Readcount=0)读进程,申请对数据对象的读权(与写进程互斥) 修改计数变量Readcount(加1) 释放计数变量Readcount的使用 读数据对象 申请修改读进程计数变量Readcount(临界资源) 修改计数变量Readcount(减1) 若为末位(Readcount=0)读进程,释放对数据对象的读权(与写进程互斥) 释放临界资源(计数变量Readcount)的使用 ,Wait(Rmutex),Signal(Rmutex),Wait(Wmutex),Signal(Wmutex),Wait(Rmutex),Signal(Rmutex), 申请对数据对象的写权(与读写进程互斥) 写数据 释放对数据对象的写权(与读写进程互斥) ,某个写进程写数据,Wait(Wmutex),Signal(Wmutex), wait(rmutex); if(readcount= =0) wait(wmutex);/*第一位读者阻止写者*/ readcount+; V(rmutex); 读数据; wait(rmutex); re
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 内蒙古自治区通辽市科左后旗甘旗卡第二高级中学2025-2026学年高二上化学期末检测模拟试题含解析
- 重庆三峡医药高等专科学校《建筑施工组织及BIM应用》2024-2025学年第一学期期末试卷
- 2025-2026学年上海市金山区金山中学物理高二第一学期期末教学质量检测试题含解析
- 疾病预防控制策略
- 河南省九师.商周联盟2025-2026学年生物高一第一学期期末达标检测试题含解析
- 血液透析并发症护理培训
- 艾滋病综合管理方案
- 精神科抑郁症患者心理疏导方法
- 眼科白内障手术后护理方案
- 康复医学科脊柱骨折康复护理方案
- 强国必须强军强军才能国安
- 实验室质量管理体系建立与运行课件
- 青少年药物滥用的预防和干预
- 插扣式脚手架施工方案
- 焊材抽检记录表
- 建设用地规划许可证审批表
- 国家开放大学《小城镇建设》形考任务1-4参考答案
- 咳嗽的诊断与治疗指南
- 车架设计手册
- 公路桥梁施工安全和质量控制要点
- 水工-建筑物课件
评论
0/150
提交评论