《操作系统》PV习题课1.ppt
《《操作系统》PV习题课1.ppt》由会员分享,可在线阅读,更多相关《《操作系统》PV习题课1.ppt(29页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、进进 程程 概概 念(一)念(一)问题:如果系统中有问题:如果系统中有N个进程,个进程,运行进程最多几个,最少几个?运行进程最多几个,最少几个?就绪进程最多几个,最少几个?就绪进程最多几个,最少几个?等待进程最多几个,最少几个?等待进程最多几个,最少几个?运行运行就绪就绪等待等待进程的状态及其转换进程的状态及其转换解答:解答:运行进程最多运行进程最多1 1个,最少个,最少0 0个;个; 就绪进程最多就绪进程最多N-1-1个,最少个,最少0 0个;个; 等待进程最多等待进程最多N个,最少个,最少0 0个;个;概念:概念: (1)(1)进程、进程的基本状态;进程、进程的基本状态;单单CPU;进程切
2、换瞬间;进程切换瞬间;系统进程、用户进程;系统进程、用户进程; (2)(2)死锁(不是死锁(不是“死机死机”););进进 程程 概概 念(一)念(一)进进 程程 概概 念(二)念(二)问题:问题:进程有无如下状态转换,为什么?进程有无如下状态转换,为什么?(1)等待)等待运行运行 (2)就绪)就绪等待等待解答:解答:(1)不能:)不能:等待就绪运行等待就绪运行 (2)不能:)不能:就绪运行等待就绪运行等待问题:问题:一个转换发生,是否另一个转换一一个转换发生,是否另一个转换一定发生?找出所有的可能。定发生?找出所有的可能。解答:解答: 就绪就绪运行运行: : 不一定(系统中仅一个进程)不一定(
3、系统中仅一个进程) 转换条件:被调度程序选中转换条件:被调度程序选中 运行运行就绪就绪: : 一定(讨论就绪队列的长度)一定(讨论就绪队列的长度) 转换条件:时间片到时转换条件:时间片到时, ,或有更高优先级或有更高优先级 的进程出现的进程出现进进 程程 概概 念(三)念(三)解答:解答: 运行运行等待等待: : 不一定(考虑死锁)不一定(考虑死锁)转换条件:等待某事件发生转换条件:等待某事件发生 等待等待就绪就绪: : 不一定不一定转换条件:等待的事件发生转换条件:等待的事件发生进进 程程 概概 念(三)念(三)进进 程程 概概 念(四)念(四)问题:问题:日常生活中的日常生活中的“进程进程
4、”举例举例解答:解答:两个角度:两个角度:“程序程序- -数据数据- -运行运行” 或或“资源资源- -调度调度- -运行运行”经典例子:经典例子:“按照菜谱作菜按照菜谱作菜”“”“乐队演乐队演奏奏”或或“向服务员请求服务向服务员请求服务”等等进程同步和互斥(一)进程同步和互斥(一)问题:问题:用用P.VP.V操作解决下图之同步问题操作解决下图之同步问题getcopyputfstg进程同步和互斥(一)进程同步和互斥(一)cpcgpcgpg一个数据上的操作顺序:一个数据上的操作顺序:get - copy - putGet不能向不能向“满满”的的S中放;中放;Copy不能从不能从“空空”的的S中取
5、;不能向中取;不能向“满满”的的T中中放;放;Put不能不能“空空”的的T中取中取(同步)信号量:(同步)信号量:实际上也起到互斥作用实际上也起到互斥作用S_Empty, T_Empty, 初值为初值为1S_Full, T_Full; 初值为初值为0Get:Begin Repeat P(S_Empty) T_get_S(); V(S_Full); Until false;EndCopy:Begin Repeat P(S_Full); P(T_Empty); S_copy_T(); V(T_Full); V(S_Empty); Until false;EndPut:Begin Repeat P(
6、T_Full); T_put_G(); V(T_Empty); Until false;End进程同步和互斥(二)进程同步和互斥(二)问题:用问题:用P.V操作解决下面问题操作解决下面问题司机进程:司机进程:REPEAT启动车辆启动车辆正常驾驶正常驾驶到站停车到站停车UNTIL 售票员进程:售票员进程:REPEAT关门关门售票售票开门开门UNTIL 信号量:信号量:S_Door, 初值为初值为0S_Stop; 初值为初值为0司机进程司机进程:Begin Repeat P(S_Door); 启动;启动; 驾驶;驾驶; 停车;停车; V(S_Stop); Until false;End乘务员进程乘
7、务员进程:Begin Repeat 关门;关门; V(S_Door); 售票;售票; P(S_Stop); 开门;开门; Until false;End同步要求:先关门,后开车;同步要求:先关门,后开车; 先停车,后开门先停车,后开门问题:问题:推广读写者问题中的消息缓冲处理。消推广读写者问题中的消息缓冲处理。消息缓冲区为息缓冲区为k个,有个,有m个发送进程,个发送进程,n个个接收进程,每个接收进程对发送来的消接收进程,每个接收进程对发送来的消息都必须取一次息都必须取一次 进程同步和互斥(三)进程同步和互斥(三)Type BufferType = Recordmsg:MessageType;c
8、ount:integer;mutex:semaphore; 初值为初值为1empty: semaphore; 初值为初值为1full: array 1.n of semaphore; 初值全为初值全为0EndVar mutex: semaphore; 初值为初值为1s: integer; 初值为初值为0buff: array 0.k-1 of BufferType; k是缓冲区大小;是缓冲区大小; n是接收进程个数是接收进程个数 m是发送进程个数,通过是发送进程个数,通过 s 进行进行“写互斥写互斥” Procedure Sender_i(i:integer); i 为发送进程的标号为发送进程
9、的标号Vars0, j: integer;Begin Repeat P(mutex); s0:=s; s:=(s+1) mod k; V(mutex); P(buffs0.empty); 在在buffs0.msg中写信息;中写信息; P(buffs0.mutex); buffs0.count:=n; V(buffs0.mutex); For (j:=1 to n do) V(buffs0.fullj); Until false;EndProcedure Recvr(i:integer); i 为接收进程的标号为接收进程的标号Varj: integer;Begin j:=0; Repeat P(
10、buffj.fulli); 从从buffj.msg中读信息;中读信息; P(buffj.mutex); buffj.count:= buffj.count-1; If (buffj.count=0) Then V(buffj.empty); V(buffj.mutex); j:=(j+1) mod kUntil false;End第二类读者写者问题(写者优先)第二类读者写者问题(写者优先)1 1)共享读)共享读2 2)互斥写、读写互斥)互斥写、读写互斥3 3)写者优先于读者(一旦有写者,则后续)写者优先于读者(一旦有写者,则后续读者必须等待,唤醒时优先考虑写者)读者必须等待,唤醒时优先考虑写者
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 PV 习题
限制150内