- 1、本文档共32页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
操作系统3 2
第三章 进程管理 sh_licsy@163.com 3.5 进程互斥 3.5 进程互斥 3.5 进程互斥 临界资源、临界区 例:有两个进程A和B,它们共享一个变量x,且两个进程按以下方式对变量X进行访问和修改: 其中R1和R2为处理机中的两个寄存器。 A与B均对X+1,即X+2。 若按另一顺序对变量进行修改: 结果x只加了1。 临界资源、临界区 例2:getspace和release: getspace: begin local g g stack[top] top top-1 end release(ad): begin top top+1 stack[top] ad end 两个进程公用一个堆栈,堆栈是临界资源;访问堆栈的程序段就是临界区。 临界资源、临界区 为了保证临界资源的正确使用,可以把临界资源的访问过程分成以下几部分: 临界资源、临界区 互斥的定义 互斥的定义: 不允许两个以上的共享某一公有资源的并发进程同时进入临界区称为互斥。 一组并发进程互斥执行需满足的准则 互斥的加锁实现 原理:当某个进程进入临界区之后,它将锁上临界区;直到它退出临界区时为止。 并发进程在申请进入临界区时,首先测试该临界区是否是上锁的,如果该临界区已被锁住,则该进程要等到该临界区开锁之后才有可能获得临界区 加锁后的临界区程序描述: Lock(key[s]); (临界区) unLock(key[s]); ①引入锁定位key[s]=1(资源可用)或0(资源不可用) ② Lock(key[s])定义三个动作: a. 检查key[s]是否为1; b. 若key[s]=1,则key[s]=0; c. 若key[s]=0,则返回a继续检测。 ③unLock(key[s])定义一个动作:key[s] 1 。 问题: Lock(key[s])必须满足 key[s]=0时,不允许任何进程进入临界区;key[s]=1时,仅允许一个进程进入临界区,实现起来较困难。 信号量(Sem)的物理意义: ①信号量(Sem)是一整数; ②当sem ? 0时代表可供并发进程使用的资源实体的数目; ③当sem 0时则表示正在等待使用资源(如临界区)的进程数目。 信号量使用时应注意的问题: 用于进程互斥的信号量sem的初值应该大于零;建立一个信号量时必须说明所建信号量所代表的意义(物理)并赋初值。 P操作的定义: ①信号量sem减1; ②若sem减1后仍大于等于零,则进程继续执行; ③若sem减1后小于零,则该进程被阻塞后加入与该信号相对应的等待队列中,然后转进程调度。 P操作流程图 V操作的定义: ①信号量sem加1; ②若sem加1后仍大于零,则进程继续执行; ③若sem加1后小于或等于零,则从与该信号相对应的等待队列中唤醒一个等待进程,然后返回原进程继续执行或转进程调度。 信号量的值仅能由P、V原语操作改变。 V操作流程图 实现P、V原语的软件方法:加锁法 P(sem): Begin 封锁中断; lock(lockbit) val[sem]=val[sem]-1 if val[sem]0 保护当前进程CPU现场; 把当前进程状态置为等待; 将当前进程插入信号量sem的等待队列; 转进程调度; fi unlock(lockbit); 开放中断; end 实现P、V原语的软件方法:加锁法 V(sem): Begin 封锁中断; lock(lockbit) val[sem]=val[sem] + 1 if val[sem]? 0 local K; 从sem等待队列中选取一个等待进程,将其指针置入K中; 将K插入就绪队列; 进程状态置“就绪” fi unlock(lockbit); 开放中断; end 用P、V操作实现简单的进程互斥或同步 解决此类问题的一般方式: 根据问题给出的条件,确定进程有几个或几类; 确定进程间的制约关系——是互斥,还是同步; 各相关进程间通过什么信号量实现彼此的制约,标明信号量的含义和初值。 用P、V操作写出相应
您可能关注的文档
- 干净清新背景壁纸.ppt
- 平面卡通小人 黑白.ppt
- 常见的非金属及其化合物第四章 第1讲.ppt
- 幻灯片模板 向日葵.ppt
- 幻灯片模板 咖啡.ppt
- 幻灯片模板 素蓝.ppt
- 平喘药试验.ppt
- 平面设计大师西摩·切瓦斯特 作品赏析.ppt
- 幻灯片模板3.ppt
- 幼儿绘本故事 阿利的红斗篷.ppt
- 讲稿:深入理解“五个注重”把握进一步深化改革统筹部署以钉钉子精神抓好落实.pdf
- 副市长在2025年全市医疗工作会议上的讲话.docx
- 2025年市县处级以上党委(党组)理论学习中心组专题学习计划.docx
- 市民族宗教事务局党组书记、局长2024年度民主生活会个人对照检视发言材料.docx
- 烟草局党组书记2024年度抓基层党建工作述职报告.docx
- (汇编)学习2025年全国教育工作会议精神心得体会发言心得感悟.pdf
- 汇编学习领会在二十届中纪委四次全会上的重要讲话精神心得体会.pdf
- 在2025年镇安全生产、消防安全和生态环境保护第一次全体会议上的讲话提纲.docx
- 书记干部座谈会上的讲话+纪委全会上的讲话.pdf
- 党课:从毛泽东诗词中感悟共产党人初心使命.docx
最近下载
- 外研版 选择性必修第二册Unit3 Times change Developing ideas 课件.pptx
- 带头严守政治纪律和政治规矩,维护党的团结统一等四个方面存在的问题与整改材料4.docx VIP
- 市政工程竣工验收流程图汇.doc
- 【新教材】统编版高中历史选择性必修3《文化交流与传播》教学计划(含教学进度表).pdf
- 2024年苏州卫生职业技术学院单招语文考试试题及答案解析.docx
- 美的-风冷热泵模块机组技术手册.pdf
- 2024年长沙职业技术学院单招语文考试试题及答案解析.docx
- 2024年高中生物晨背和晚背知识点.doc
- 医院培训课件:《护理查对制度》.pptx
- 高中数学教学中的学生自主学习能力分析教学研究课题报告.docx
文档评论(0)