[经济学]电子科技大学计算机操作系统—第2章 进程管理.ppt

[经济学]电子科技大学计算机操作系统—第2章 进程管理.ppt

  1. 1、本文档共89页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[经济学]电子科技大学计算机操作系统—第2章 进程管理

一般信号量集机制定义 2.6 “信号量集”机制 2.6 “信号量集”机制 一般:“信号量集”的几种特殊情况: ⑴ SP(S,d,d) 此时的信号量集已蜕化为一般信号量,但它允许每次申 请d个资源,当现有资源数少于d时,不予分配; ⑵ SP(S,1,1) 此时的信号量集又蜕化为计数信号量(S1时)或互斥 信号量(S=1时); ⑶ SP(S,1,0) 当S≥1时,允许多个进程进入某特定区;当S变为0后,将阻止任何进程进入特定区。即它相当于一个“可控开关”。 2.7 经典的进程同步问题 问 题? 一组生产者进程 P i(P1,P2,… Pk) 一组消费者进程 C i(C1,C2,… Cm) 互斥使用由n个缓冲区组成的缓冲池。 out C i P i 一、 生产者—消费者问题(producer-consumer problems) in out in out C i P i n 0 0 2.7 经典的进程同步问题 1.同步关系: ? 当缓冲池放满产品时生产者必须等待。 定义生产者进程同步信号量: empty — 表示空闲缓冲区数。 0 ≤ empty ≤ n empty 初值为 ; ?当缓冲池空时,消费者进程必须等待。 定义消费者进程同步信号量 : full — 表示有产品的缓冲区数。 0 ≤ full ≤ n full 初值为 ; 2.互斥关系:两组进程中的每个进程必须互斥的使 用缓冲区。 定义公共互斥信号量: mutex初值为 1 3.定义: in ,out 分别表示首空缓冲区序号及 首满缓冲区序号。 0 in out C i P i 2.7 经典的进程同步问题 2.7 经典的进程同步问题 一、 生产者—消费者问题(producer-consumer problems) empty — 表示空闲缓冲区数。 初值为 n empty = 0 缓冲区全满,生产者进程不能工作。 full — 表示有产品的缓冲区数。 初值为 0 full = 0 缓冲区全空,消费者进程不能工作。 in out C i P i 一、 生产者—消费者问题(producer-consumer problems) empty — 表示空闲缓冲区数。 初值为 n empty = 0 缓冲区全满,生产者进程不能工作。 full — 表示有产品的缓冲区数。 初值为 0 full = 0 缓冲区全空,消费者进程不能工作。 out C i P i in 2.7 经典的进程同步问题 2. 7 经典的进程同步问题 一、 生产者—消费者问题(producer-consumer problems) empty — 表示空闲缓冲区数。 初值为 n empty = 0 缓冲区全满,生产者进程不能工作。 full — 表示有产品的缓冲区数。 初值为 0 full = 0 缓冲区全空,消费者进程不能工作。 in out P i C i ?检查有否空缓冲区 ?释放缓冲区 释放缓冲区? 2.7 经典的进程同步问题 生产者—消费者问题算法 生产者进程: 生产一个产品 m ; . . . P(empty); P(mutex); 将产品 m放入缓冲区; in:=(in +1)mod n ; V (mutex); V( full); . . Var mutex,empty,full:semaphore :=1, n , 0; buffer:array [0 . .n-1] of message; in, out : 0..n-1:= 0,…0 消费者进程: . . .

文档评论(0)

skvdnd51 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档