- 35
- 0
- 约2.79千字
- 约 21页
- 2018-07-09 发布于江苏
- 举报
进程间的相互作用
进程间的相互作用 进程间的联系 进程的同步机制 ──信号量及P.V操作(解决进程同步互斥问题) 进程间的联系 相交进程与无关进程 相交进程:指多个并发进程在逻辑上有某种联系 无关进程(不相交进程): 在逻辑上无任何联系的进程 直接作用和间接作用 直接作用: 进程间的相互联系是有意识的安排的,直接作用只发生在相交进程间 间接作用: 进程间要通过某种中介发生联系,是无意识安排的,可发生在相交进程之间,也可发生在无关进程之间 进程的同步(直接作用) 进程的同步: 指系统中多个进程中发生的事件存在某种时序关系,需要相互合作,共同完成一项任务。具体说,一个进程运行到某一点时要求另一伙伴进程为它提供消息,在未获得消息之前,该进程处于等待状态,获得消息后被唤醒进入就绪态 例: 司机 P1 售票员 P2 while (true) while (true) { { 启动车辆; 关门; 正常运行; 售票; 到站停车; 开门; } } 进程的互斥(间接作用) 由于各进程要求共享资源,而有些资源需要互斥使用,因此各进程间竞争使用这些资源,进程的这种关系为进程的互斥。 临界资源: 系统中某些资源一次只允许一个进程使用,称这样的资源为 临界资源 或 互斥资源 或共享变量。 临界区(互斥区) 一个程序片段的集合,这些程序片段分散在不同的进程中,对某个共享的数据结构(共享资源)进行操作 在进程中涉及到临界资源的程序段叫临界区 多个进程的临界区称为相关临界区 临界区(互斥区)原理 临界区(互斥区)举例 使用互斥区的原则: 有空让进:当无进程在互斥区时,任何有权使用互 斥区的进程可进入 无空等待:不允许两个以上的进程同时进入互斥区 多中择一:当没有进程在临界区,而同时有多个进 程要求进入临界区,只能让其中之一进 入临界区,其他进程必须等待 有限等待:任何进入互斥区的要求应在有限的时间 内得到满足 让权等待:处于等待状态的进程应放弃占用CPU, 以使其他进程有机会得到CPU的使用权 使用互斥区的原则 前提:任何进程无权停止其它进程的运行 进程之间相对运行速度无硬性规定 进程互斥的解决有两种做法: 由竞争各方平等协商 引入进程管理者,由管理者来协调竞争各方对互斥资源的使用 具体方法: 硬件(当一个进程进入临界区,就屏蔽所有中 断,但成本高) 软件(用编程解决,但常常忙等待 ) 进程互斥的软件方法 通过平等协商方式实现进程互斥的最初方法是软件方法 其基本思路是在进入区检查和设置一些标志,如果已有进程在临界区,则在进入区通过循环检查进行等待;在退出区修改标志 其中的主要问题是设置什么标志和如何检查标志 软件解法 (1) free: 表示临界区标志 true: 有进程在临界区 false:无进程在临界区(初值) .... while (free); free = true; 临界区 free = false; 软件解法 (2) turn: true P进入临界区 false Q进入临界区 .... P: while (not turn); Q: while (turn); 临界区 临界区 turn = false; turn = true; 软件解法(3) pturn,qturn: 初值为false P进入临界区的条件: pturn∧ not qturn Q进入临界区的条件: not pturn∧ qturn P .... Q ..... pturn = true; qturn = true; while (qturn); while (pturn); 临界区 临界区 pturn = false; qturn = false;
您可能关注的文档
最近下载
- 2022年注册土木工程师(道路工程)《专业案例考试(下)》真题及答案解析.docx VIP
- 2025年辽宁省交通高等专科学校单招《数学》测试卷带答案详解(基础题).docx VIP
- 中国肺血栓栓塞症诊治、预防和管理指南(2025版)解读.pptx
- 版上市公司行业分类申万.pdf VIP
- GB_T28043-2019利用实验室间比对进行能力验证的统计方法.docx VIP
- 职业技能鉴定考试《电梯安装维修工高级》全真试题及答案.docx VIP
- 2025年辽宁省交通高等专科学校单招语文测试试卷题型大全.docx VIP
- 标准图集-22G101-3 混凝土结构施工图平面整体表示方法制图规则和构造详图-独立基础、条形基础、筏形基础、桩基础.pdf VIP
- 中考数学总复习《一次函数中角度问题》专项检测卷(含答案).docx VIP
- 汽车零件质量分析案例.pptx VIP
原创力文档

文档评论(0)