进程并发与互斥.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文档。上传文档
查看更多
进程并发与互斥

3.5 进程并发与互斥;3.5.1 互斥算法;3.5.1.1 临界资源;共享变量的修改冲突;操作顺序冲突;有6种可能的操作顺序,只有一种结果是正确的。;互斥:指多个进程不能同时使用同一个资源;3.5.1.2 临界区的访问过程;临界区(critical section):进程中访问临界资源的一段代码。 进入区(entry section):在进入临界区之前,检查可否进入临界区的一段代码。如果可以进入临界区,通常设置相应“正在访问临界区”标志 退出区(exit section):用于将“正在访问临界区”标志清除。 剩余区(remainder section):代码中的其余部分。;。 两个进程不能同时进入访问同一临界资源的临界区,这称为进程互斥。;3.5.1.3 互斥机制应遵循的准则;1、进程互斥的软件方法;算法如下: Process P (1) Process P (2) Begin begin …… …… While (key[S]= 0) do skip; While (key[S]= 0) do skip; key[S] = 0; key[S] = 0; Critical section; Critical section; key[S] = 1; key[S] = 1; …… …… end. end. ;2、进程互斥的硬件方法;互斥算法(TS指令);Swap指令(或Exchange指令);互斥算法(Swap指令);优点 适用于任意数目的进程,在单处理器或多处理器上更显其优越 简单,容易验证其正确性 可以支持进程内存在多个临界区,只需为每个临界区设立一个布尔变量 缺点 等待要耗费CPU时间,即“忙等”,不能实现“让权等待” 可能产生“饿死”现象:有的进程可能永远执行不了;试考虑以下进程PA和PB反复使用临界区的情况: PA A:lock(key[S]) 〈S〉 unlock(key[S]) Goto A PB B:lock(key [S]) <S> unlock(key [S]) Goto B ;3.5.2 信号量(semaphore);3.5.2.1 信号量和P、V原语;信号量只能通过初始化和两个标准的原语来访问——作为OS核心代码执行,不受进程调度的打断 初始化资源信号量为指定一个非负整数值,表示空闲资源总数——若为非负值表示当前的空闲资源数,若为负值其绝对值表示当前等待临界区的进程数;1.P操作原语 procedure P(var s:semaphore) begin s:=s-1; if s0 then W(s); end ;w(s)表示将调用P操作原语的进程置成等待信号量s的状态。 进程执行P操作时,首先将信号量s减1,其结果若s≥o,则该进程继续运行;若结果so则阻塞该进程,并把它插入到信号量s的等待队列中。; 2.V操作原语 Procedure V(var s:semaphore) begin s:=s+1; if s≤0 then R(s); end ;R(s)表示从信号量s的等待队列中释放一个进程。 进程执行V操作时,首先将信号量s加1,如果so,则该进程继续执行。如果s≤0则释放s信号量等待队列中队首的进程,解除其阻塞状态。调用V操作的当前进程继续执行。;P、V操作的物理意义: 执行P操作:;在此之后若又有进程请求该资源,在该进程调用P操作时,s减1后成为负值,则执行W(s),该进程将转换为阻塞态并进入信号量s对应的等待队列中。 当信号量s为负值时,它的绝对值表示在该信号量等待队列中的进程数目。;执行V操作时: s:=s+1意味着调用V操作的进程释放了一个信号量s对应的资源。 s加一后,若s为负值,表明s对应的等待队列中仍有等待该资源的阻塞进程,则调用R(s)释放等待队列中的一个进程。;被释放的进程是在执行P操作时因资源不足而进入阻塞态的,由于V操作释放了它所需的资源,它就转换为就绪态可以继续执行。; 记录型信号量;1

文档评论(0)

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

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

版权声明书
用户编号:5134022301000003

1亿VIP精品文档

相关文档