![2[1].4__经典进程的同步问题_第1页](http://file.renrendoc.com/FileRoot1/2019-7/20/ed9c171e-1cd9-49d9-b5d7-44cf2ecdf68d/ed9c171e-1cd9-49d9-b5d7-44cf2ecdf68d1.gif)
![2[1].4__经典进程的同步问题_第2页](http://file.renrendoc.com/FileRoot1/2019-7/20/ed9c171e-1cd9-49d9-b5d7-44cf2ecdf68d/ed9c171e-1cd9-49d9-b5d7-44cf2ecdf68d2.gif)
![2[1].4__经典进程的同步问题_第3页](http://file.renrendoc.com/FileRoot1/2019-7/20/ed9c171e-1cd9-49d9-b5d7-44cf2ecdf68d/ed9c171e-1cd9-49d9-b5d7-44cf2ecdf68d3.gif)
![2[1].4__经典进程的同步问题_第4页](http://file.renrendoc.com/FileRoot1/2019-7/20/ed9c171e-1cd9-49d9-b5d7-44cf2ecdf68d/ed9c171e-1cd9-49d9-b5d7-44cf2ecdf68d4.gif)
![2[1].4__经典进程的同步问题_第5页](http://file.renrendoc.com/FileRoot1/2019-7/20/ed9c171e-1cd9-49d9-b5d7-44cf2ecdf68d/ed9c171e-1cd9-49d9-b5d7-44cf2ecdf68d5.gif)
已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 高三上半学期化学知识总结
- 塔里木大学《医学检验仪器与临床实验室管理》2023-2024学年第一学期期末试卷
- 2025至2031年中国建筑专用型材行业投资前景及策略咨询研究报告
- 2025至2031年中国内置号角喇叭行业投资前景及策略咨询研究报告
- 2025年商场租赁合同
- 济宁铁路隔音屏施工方案
- 2025至2030年中国进水三通数据监测研究报告
- 2025至2030年中国薄荷素油数据监测研究报告
- 2025至2030年中国祛黑嫩白霜数据监测研究报告
- 2025至2030年中国液态感光丝网抗蚀剂数据监测研究报告
- 四川省达州市普通高中2025届第二次诊断性测试物理试题及答案
- 2025年广东省深圳市21校初三一模英语试题及答案
- 2025年河南交通职业技术学院单招职业适应性测试题库带答案
- 关于纳粹德国元首希特勒的历史资料课件
- 志愿服务证明(多模板)
- 部编版语文一年级下册识字8-人之初市级优质课课件
- 基于仿真的轴承动力学分析设计毕业设计说明书
- 丽声北极星分级绘本第二级下Eek,Spider 教学设计
- (高清正版)JJF 1908-2021 双金属温度计校准规范
- 测量成果验收单
- 毕业设计(论文)-助力式下肢外骨骼机器人的结构设计
评论
0/150
提交评论