PV复习.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PV复习

本课程内容 第1章 绪论 第2章 操作系统用户界面 第3章 进程管理 第4章 处理机调度 第5章 存储管理 第8章 文件系统 第9章 设备管理 * 例4:三个进程PA、PB和PC协作解决文件打印问题:PA将文件记录从磁盘读入主存的缓冲区1,每执行一次读一个记录;PB将缓冲区1的内容读出并读入到缓冲区2,每执行一次读出并读入一个记录;PC将缓冲区2的内容打印出来,每执行一次打印一个记录。缓冲区1的大小和m个记录大小一样,缓冲区2的大小和n个记录大小一样。请用P、V操作来保证文件的正确打印。 解答:设置四个信号量empty1、empty2、full1、full2、mutex1和mutex2,信号量empty1和empty2分别表示缓冲池1和缓冲池2是否为空,其初值为m和n;信号量full1和full2分别表示缓冲池1和缓冲池2是否有记录供读出,其初值均为0;信号量mutex1和mutex2分别表示对缓冲池1和缓冲池2的访问互斥,其初值为1。其进程间的同步与互斥关系如下: int empty1=m; int empty2=n; int full1=0; int full2=0; int mutex1=1; int mutex2=1; main() { PA(); PB(); PC(); } PA( ) {while(1) { 从磁盘读出一个文件记录; p(empty1); p(mutex1); 将一个文件记录读入缓冲池1; v(mutex1); v(full1); } } PB( ) {while(1) { p(full1); p(mutex1); 从缓冲区1中读出一个文件记录; v(mutex1); v(empty1); p(empty2); p(mutex2); 将一个记录读入缓冲区2; v(mutex2); v(full2); } } PC( ) {while(1) { p(full2); p(mutex2); 从缓冲池2读出一个文件记录打印; v(mutex2); v(empty2); } } 例5:有三个进程A、B、C,其中A与B构成一对生产者和消费者,共享一个由n个缓冲区块组成的缓冲池1;B与C也构成一对生产者与消费者,共享另一个由m个缓冲块组成的缓冲池2。用P、V操作描述它们之间的同步关系。 解答: 设置四个信号量empty1、empty2、full1和full2,其同步关系描述如下: int empty1=n; /*表示缓冲池1中的空缓冲区数*/ int empty2=m; /*表示缓冲池2中的空缓冲区数*/ int full1=0; /* 表示缓冲池1中装满产品的缓冲区数*/ int full2=0; /* 表示缓冲池2中装满产品的缓冲区数*/ main( ) { cobegin PA( ); PB( ); PC( ); Coend } PA( ) { while(1) { 生产一件产品; P(empty1); 将一件产品放入缓冲池1; V(full1); } } PB( ) { while(1) { P(full1); 从缓冲池1中取出一件产品; V(empty1); P(empty2); 将一件产品放入缓冲池2; V(full2); } } *

文档评论(0)

ma33756 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档