网站大量收购闲置独家精品文档,联系QQ:2885784924

信号量与PV操作.pptVIP

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

前面的例子里生产者和消费者共享的是一个缓冲区,实际上,他们也可以共享多个缓冲区。01为了实现协调,必须增加一个信号量。02mutex信号量(初值1),使进程互斥地访问缓冲区03empty信号量(初值k),保证生产者不向满的缓冲区存04full信号量(初值0),保证消费者不从空的缓冲区取05一个生产者一个消费者共享多个缓冲区semaphorefull;full=0;intout=0;intB[k];semaphoreempty;empty=k;intin=0;semaphoremutex;mutex=1;020304050601m个消费者和n个生产者共享多个缓冲区cobeginprocessproducer_i(){while(true){produce();P(empty);P(mutex);append()toB[in];in:=(in+1)%k;V(mutex);V(full);}}coend;processconsumer_j(){while(true){P(full);P(mutex);take()fromB[out];out=(in+1)%k;V(mutex);V(empty);consume();}}实例分析情况一(producer在临界区中,consumer加入)producer_i:P(empty);(empty=k-1)P(mutex);(mutex=0)临界区consumer_i:P(full);(full=-1;)挂起producer_i:V(mutex);(mutex=1)V(full);(full=0;)(唤醒consomer_i)comsumer_i:P(mutex);(mutex=0;)临界区;V(mutex);(mutex=1;)V(empty);(empty=k)实例分析情况二:(consumer先启动)consumer_i:P(full);(full=-1;)挂起producer_i:P(empty);(empty=k-1;)P(mutex);(mutex=0)临界区;V(mutex);(mutex=1)V(full);(full=0;)comsumer_i:P(mutex);(mutex=0;)临界区;V(mutex);(mutex=1;)V(empty);(empty=k)P操作的次序如果有多个P操作,必须注意它们之间的顺序一般来说,用于互斥的信号量上的P操作应该在后面。V操作的次序无关紧要。讨论:如果在生产者进程中将P(mutex)和P(empty)交换则若缓冲区已满(empty=0;full=k;mutex=1;),则producer:P(mutex);(mutex=0)P(empty);(empty=-1;)挂起consumer:P(full);(full=k-1);P(mutex);(mutex=-1);挂起写者执行写操作前,应让已有的写者和读者全部退出03任一写者在完成写操作之前不允许其它读者或写者工作02允许多个读者同时执行读操作01有两组并发进程:读者和写者,共享一个文件F,要求:读者写者问题OperatingSystemOS操作系统郑州大学申丰山OperatingSystemOS操作系统郑州大学申丰山OperatingSystemOS操作系统郑州大学申丰山Ope

文档评论(0)

189****6885 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档