生产者与消费者之间的同步与互斥问题.PPTVIP

生产者与消费者之间的同步与互斥问题.PPT

  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文档。上传文档
查看更多
生产者与消费者之间的同步与互斥问题

问题描述 一个仓库可以存放K件物品。生产者每生产一件产品,将产品放入仓库,仓库满了就停止生产。消费者每次从仓库中去一件物品,然后进行消费,仓库空时就停止消费。 生产者与消费者问题是许多相互合作进程的一种抽象。例如,在输入时,输入进程是生产者,计算进程是消费者。在输出时,计算进程是生产者,打印进程是消费者。 生产者与消费者之间的同步与互斥问题 同步问题: 1.只要缓冲池未满,生产者便可将消息送入缓冲池,否则等待。 2.只要缓冲池未空,消费者便可从缓冲池中取走一个消息,否则等待。 互斥问题: 1.生产者与生产者之间、消费者与消费者之间互斥访问缓冲池。 2.生产者和消费者之间互斥访问缓冲池。 生产者/消费者问题 一个生产者,一个消费者,一个缓冲区 确定同步对象 确定同步约束条件 确定同步时机 定义信号量:考虑为每个同步对象设一个信号量 用wait()操作判断同步条件是否满足 用signal()操作向其它同步对象发同步信号 Var mutex, empty, full:semaphore∶=1,n,0; buffer:array[0, …, n-1] of item; in, out: integer∶=0, 0; proceducer:begin repeat producer an item nextp; wait(empty); wait(mutex); buffer(in)∶=nextp; in∶=(in+1) mod n; signal(mutex); signal(full); until false; end consumer:begin repeat wait(full); wait(mutex); nextc∶ =buffer(out); out∶ =(out+1) mod n; signal(mutex); signal(empty); consumer the item in nextc; until false; end Thank you !! 姚俊 朱景焕 宋聪 郭涛 欧阳睿 朱思勇 杨凝 熊伟 唐沐 万骞 闫弈潼 * 例 1 电子邮件信箱 发送进程 A 接收进程 B 当信箱满时,发送进程只有等待接收进程取走信件,当信箱空时,接收进程必须等待发送进程发送信件。 1 2 n …… 进程间的关系 生产者生产消息 后 消费者消费的合作关系 消费者消费 后 的空白缓冲块由生产者生产消息的合作关系 进程间在队列操作上的互斥关系 * * * 发送进程A:送信次序为:1,2,…. 接收进程B:收信次序为:1,2,….. 同步的含义为,当信箱满时,必须在接受进程B取走信后,A才能发信。

文档评论(0)

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

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

1亿VIP精品文档

相关文档