秋霞电影网午夜鲁丝片无码,真人h视频免费观看视频,囯产av无码片毛片一级,免费夜色私人影院在线观看,亚洲美女综合香蕉片,亚洲aⅴ天堂av在线电影猫咪,日韩三级片网址入口

第3章 處理器管理

收藏

編號:239608223    類型:共享資源    大?。?span id="mzebxcnn0" class="font-tahoma">4.36MB    格式:PPT    上傳時間:2024-02-07
10
積分
關 鍵 詞:
第3章 處理器管理 處理器 管理
資源描述:
L/O/G/O第三章第三章第三章第三章 處理器管理處理器管理處理器管理處理器管理mxh處理器管理的地位處理器管理的地位處理器管理的地位處理器管理的地位mxh主要內容主要內容主要內容主要內容3.1 3.1 進程的引入程的引入3.23.2進程的概念程的概念3.33.3進程控制程控制3.43.4線程程3.53.5處理器理器調度度3.63.6調度算法度算法3.73.7處理器理器調度和度和實時調度度mxh3.1.13.1.13.1.13.1.1程序的執(zhí)行方式程序的執(zhí)行方式程序的執(zhí)行方式程序的執(zhí)行方式(順序順序順序順序)順序序執(zhí)行行特征:特征:順序性、封序性、封閉性、可再性、可再現(xiàn)性性I1C1P1I2C2P2mxh3.1.23.1.23.1.23.1.2程序的執(zhí)行方式程序的執(zhí)行方式程序的執(zhí)行方式程序的執(zhí)行方式(并發(fā)并發(fā)并發(fā)并發(fā))并并發(fā)執(zhí)行行I1I2I3I4C1C2C3C4P1P2P3P4tmxh3.1.13.1.13.1.13.1.1程序的執(zhí)行方式程序的執(zhí)行方式程序的執(zhí)行方式程序的執(zhí)行方式(并發(fā)并發(fā)并發(fā)并發(fā))特征特征mxh與并發(fā)有關的錯誤與并發(fā)有關的錯誤與并發(fā)有關的錯誤與并發(fā)有關的錯誤mxh3.2 3.2 3.2 3.2 進程的概念進程的概念進程的概念進程的概念問題引入引入 程序程序這個靜個靜態(tài)概念已不能如概念已不能如實反映程序并反映程序并發(fā)執(zhí)行行過程的特征。程的特征。為了深刻描述程序了深刻描述程序動態(tài)執(zhí)行行過程的性程的性質,人,人們引入引入“進程程(ProcessProcess)”概念。概念。mxh3.2 3.2 3.2 3.2 進程的概念進程的概念進程的概念進程的概念程序在程序在處理機上理機上執(zhí)行行時所所發(fā)生的活生的活動(Dijkstra)(Dijkstra)。是一個容器,是一個容器,該容器用以聚集相關容器用以聚集相關資源。源。(A.S.TanenbaumA.S.Tanenbaum)進程是一個具有獨立功能的進程是一個具有獨立功能的程序程序關于某關于某個個數(shù)據(jù)集合數(shù)據(jù)集合的的一次運行活動一次運行活動。是系統(tǒng)進。是系統(tǒng)進行資源分配和調度的單位。行資源分配和調度的單位。mxh3.2 3.2 3.2 3.2 進程的概念進程的概念進程的概念進程的概念操作操作級:圖形窗口界面形窗口界面:一個窗口就是一個一個窗口就是一個進程程打開窗口:建立一個打開窗口:建立一個進程程關關閉窗口:一個窗口:一個進程程結束束字符命令界面字符命令界面:一條命令一般就是一個一條命令一般就是一個進程程命令行尾回命令行尾回車:一個一個進程開始程開始命令命令執(zhí)行行結束束(下一命令提示符出下一命令提示符出現(xiàn)):):一個一個進程程結束束編程程級:進程建立:程建立:“建立建立進程程”函數(shù)或系函數(shù)或系統(tǒng)調用用進程程結束:束:“撤消撤消進程程”函數(shù)或系函數(shù)或系統(tǒng)調用,或者程序用,或者程序的正?;蚍钦5恼;蚍钦=Y束。束。mxh進程和程序的區(qū)別進程和程序的區(qū)別進程和程序的區(qū)別進程和程序的區(qū)別 程序靜程序靜態(tài)的,的,進程是程是動態(tài)的。的。程序和程序和進程的程的組成不同:成不同:進程程=程序程序+數(shù)據(jù)數(shù)據(jù)+PCB 程序的存在是永久的,程序的存在是程序的存在是永久的,程序的存在是暫時的。的。一個程序可以一個程序可以對應多個多個進程,一個程,一個進程可包含程可包含多個程序。多個程序。mxh進程的特征進程的特征進程的特征進程的特征動態(tài)性性:進程是個程是個動態(tài)的概念,有一定的生命周期,要的概念,有一定的生命周期,要經(jīng)歷創(chuàng)建、建、執(zhí)行、撤行、撤銷過程。程。結構性構性:它由:它由進程控制程控制塊、程序段和數(shù)據(jù)段、程序段和數(shù)據(jù)段組成成。并并發(fā)性性:在一個系:在一個系統(tǒng)內可以同內可以同時存在多個存在多個進程,它程,它們通通過交替使用交替使用處理器,從而理器,從而實現(xiàn)并并發(fā)執(zhí)行。行。異步性:異步性:指指進程之程之間在交替使用在交替使用計算機算機資源源時沒有沒有強制制的的順序,按各自獨立的、不可序,按各自獨立的、不可預知的速度向前推知的速度向前推進。獨立性:獨立性:進程是系程是系統(tǒng)分配分配資源和源和進行行調度的獨立度的獨立單位。位。mxh3.2.2 3.2.2 3.2.2 3.2.2 進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)進程的狀態(tài) 進程從程從創(chuàng)建而建而產(chǎn)生至撤生至撤銷而消亡的整個生命周期,而消亡的整個生命周期,可用一可用一組狀狀態(tài)加以刻畫,按加以刻畫,按進程在程在執(zhí)行行過程中的狀程中的狀況至少定況至少定義三種不同的三種不同的進程狀程狀態(tài):a 運行運行態(tài)(RunningRunning)a 就就緒狀狀態(tài)(ReadyReady)a 阻塞狀阻塞狀態(tài)(BlockedBlocked)當前進程已經(jīng)分配到當前進程已經(jīng)分配到CPUCPU,它的程,它的程序正在處理機上執(zhí)行的狀態(tài)。序正在處理機上執(zhí)行的狀態(tài)。已具備運行條件,但因為其他進程已具備運行條件,但因為其他進程正在占用正在占用CPU,CPU,使它暫時不能運行而使它暫時不能運行而處于等待分配處于等待分配CPUCPU的狀態(tài)。的狀態(tài)。進程因等待某種事件發(fā)生(例如等待進程因等待某種事件發(fā)生(例如等待I/OI/O操作完成,等待其他進程發(fā)來的信操作完成,等待其他進程發(fā)來的信號)而暫時不能運行的狀態(tài),也就是說,號)而暫時不能運行的狀態(tài),也就是說,處于阻塞狀態(tài)的進程尚不具備運行條件,處于阻塞狀態(tài)的進程尚不具備運行條件,即使即使CPUCPU空閑它也無法使用??臻e它也無法使用。mxh3.2.2 3.2.2 3.2.2 3.2.2 進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)引起引起進程狀程狀態(tài)轉換原因原因就就緒-運行運行時間一到,一到,調度程序度程序選擇一個新的一個新的進程運行程運行運行運行-就就緒運行運行進程用完了程用完了時間片;運行片;運行進程被中斷,因程被中斷,因為一一高高優(yōu)先先級進程程處于就于就緒狀狀態(tài)mxh3.2.2 3.2.2 3.2.2 3.2.2 進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)引起引起進程狀程狀態(tài)轉換原因原因運行運行-阻塞阻塞當一當一進程所需的程所需的東西必西必須等待等待時對一一資源的源的訪問尚不能尚不能進行行初始化初始化I/O I/O 且必且必須等待等待結果果等待某一等待某一進程提供程提供輸入入阻塞阻塞-就就緒當所等待的事件當所等待的事件發(fā)生生時mxh3.2.2 3.2.2 3.2.2 3.2.2 進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)進程三種狀程三種狀態(tài)的的轉換mxh3.2.2 3.2.2 3.2.2 3.2.2 進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)進程的狀態(tài) 有一個有一個計算機科學家,有一天女兒算機科學家,有一天女兒過生日,想生日,想親手手給女兒做一個生日蛋糕。所以他就找了一本有關做蛋女兒做一個生日蛋糕。所以他就找了一本有關做蛋糕的食糕的食譜,買了一些原料,面粉、了一些原料,面粉、雞蛋、糖、香料等,蛋、糖、香料等,然后然后邊看看邊學學邊做。做。食食譜程序;科學家程序;科學家CPUCPU;原料數(shù)據(jù);做蛋糕原料數(shù)據(jù);做蛋糕進程;程;這時小兒子哭著跑小兒子哭著跑進來,來,說手被蜜蜂手被蜜蜂蟄了。教授只了。教授只好把蛋糕先放在一好把蛋糕先放在一邊。他在食。他在食譜上做了個上做了個標記,把狀,把狀態(tài)信息信息記錄了起來。然后又去找了一本醫(yī)了起來。然后又去找了一本醫(yī)療手冊,手冊,查到了相關的內容,按照上面的指令一步步地到了相關的內容,按照上面的指令一步步地執(zhí)行。當行。當傷口口處理完之后,又回到廚房理完之后,又回到廚房繼續(xù)做蛋糕。做蛋糕。CPUCPU從一個從一個進程(做蛋糕)切程(做蛋糕)切換到另一個到另一個進程(醫(yī)程(醫(yī)療救救護)。)。mxh3.2.2 3.2.2 3.2.2 3.2.2 進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)五狀態(tài)模型:新建態(tài)新建態(tài)就緒態(tài):允許進入就緒態(tài):允許進入運行態(tài)運行態(tài)完成態(tài)完成態(tài):執(zhí)行完:執(zhí)行完mxh3.2.2 3.2.2 3.2.2 3.2.2 進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)問題出出現(xiàn)進程掛起(程掛起(suspendsuspend)進程不斷程不斷創(chuàng)建,系建,系統(tǒng)資源已不源已不滿足足進程程運行的要求,系運行的要求,系統(tǒng)就必就必須把某些把某些進程掛起,程掛起,即將即將進程程對換到磁到磁盤中,中,暫時不參與不參與進程程調度,已達到平衡操作系度,已達到平衡操作系統(tǒng)負荷的目的。荷的目的。引起引起進程掛起原因程掛起原因(P45-46(P45-46:(1)-(4)1)-(4)mxh掛起(掛起(Suspend):把一個把一個進程從內存程從內存轉到外到外存。存。激活(激活(Activate):把一個把一個進程從外存程從外存轉到到內存。內存。mxh引入掛起狀態(tài)后的七狀態(tài)模型引入掛起狀態(tài)后的七狀態(tài)模型mxhLinuxLinuxLinuxLinux進程的狀態(tài)進程的狀態(tài)進程的狀態(tài)進程的狀態(tài) D Uninterruptible sleep(usually IO)R Running or runnable(on run queue)S Interruptible sleep(waiting for an event to complete)T Stopped,either by a job control signal or because it is being traced.X dead(should never be seen)Z Defunct(zombie)process,terminated but not reaped by its parent.high-priority(not nice to other users)N low-priority(nice to other users)L has pages locked into memory(for real-time and custom IO)s is a session leaderl is multi-threaded(using CLONE_THREAD,like NPTL pthreads do)+is in the foreground process groupmxh例題例題例題例題 1 1如果系如果系統(tǒng)中有中有N N個個進程,運行的程,運行的進程最多幾個,最少幾個;就程最多幾個,最少幾個;就緒進程最程最多幾個最少幾個;等待多幾個最少幾個;等待進程最多幾個,最少幾個?程最多幾個,最少幾個?解答解答:在:在單處理機系理機系統(tǒng)中,中,處于運行狀于運行狀態(tài)的的進程最多程最多為1 1個,最少個,最少為0 0個;個;處于就于就緒進程最多程最多為N-1N-1個,最少個,最少為0 0個;個;處于阻塞的于阻塞的進程最多程最多為N N個,個,最少最少為0 0個。個。2.2.有沒有有沒有這樣的狀的狀態(tài)轉換,為什么?什么?(1 1)等待等待運行;運行;(2 2)就就緒等待等待mxh3.2.3 3.2.3 3.2.3 3.2.3 進程控制塊進程控制塊進程控制塊進程控制塊進程描述程描述進程控制程控制塊程序和數(shù)據(jù)程序和數(shù)據(jù)組成了成了進程的程的實體(靜體(靜態(tài)文本)文本)需要一個數(shù)據(jù)需要一個數(shù)據(jù)結構來描述構來描述進程當前狀程當前狀態(tài)、本身、本身特性、特性、對資源的占用以及源的占用以及調度信息等,即度信息等,即進程程控制控制塊(Process Control Block,PCBProcess Control Block,PCB)進程進程程序程序+數(shù)據(jù)數(shù)據(jù)+PCB+PCBmxh3.2.3 3.2.3 3.2.3 3.2.3 進程控制塊進程控制塊進程控制塊進程控制塊mxh3.2.3 3.2.3 3.2.3 3.2.3 進程控制塊進程控制塊進程控制塊進程控制塊PCBPCB是進程存在是進程存在的唯一標志;的唯一標志;PCBPCB常駐內存常駐內存pidpid進程狀態(tài)進程狀態(tài)現(xiàn)場現(xiàn)場優(yōu)先級優(yōu)先級阻塞原因阻塞原因程序地址程序地址同步機制同步機制資源清單資源清單鏈接指針鏈接指針mxhCPUCPUCPUCPU在進程之間的切換在進程之間的切換在進程之間的切換在進程之間的切換mxhPCBPCBPCBPCB的組織的組織的組織的組織鏈表:同一狀表:同一狀態(tài)的的進程其程其PCBPCB組成一成一鏈表,表,多個狀多個狀態(tài)對應多個不同的多個不同的鏈表。表。各狀各狀態(tài)的的進程形成不同的程形成不同的鏈表:就表:就緒鏈表、阻塞表、阻塞鏈表表mxh鏈鏈表表表表執(zhí)行指針執(zhí)行指針就緒隊列指針就緒隊列指針阻塞隊列指針阻塞隊列指針1PCB90PCB89PCB77PCB6PCB58PCB40PCB33PCB24PCB1PCBPCBPCBPCB的組織的組織的組織的組織mxhPCBPCBPCBPCB的組織的組織的組織的組織索引表:同一狀索引表:同一狀態(tài)的的進程程歸入一個入一個indexindex表表(由(由indexindex指向指向PCBPCB),多個狀),多個狀態(tài)對應多個不多個不同的同的indexindex表表各狀各狀態(tài)的的進行形成不同的索引表:就行形成不同的索引表:就緒索引表、阻塞索引表索引表、阻塞索引表mxh3.2.3 3.2.3 3.2.3 3.2.3 進程控制塊進程控制塊進程控制塊進程控制塊PCBPCB的的組織索引表索引表執(zhí)行指針執(zhí)行指針就緒表指針就緒表指針阻塞表指針阻塞表指針PCB7PCB6PCB5PCB4PCB3PCB2PCB1mxh補充補充補充補充PCBPCB和進程的代碼數(shù)據(jù)放在一起嗎?和進程的代碼數(shù)據(jù)放在一起嗎?系統(tǒng)態(tài)和用戶態(tài)系統(tǒng)態(tài)和用戶態(tài)系統(tǒng)空間和用戶空間系統(tǒng)空間和用戶空間mxh3.3 3.3 3.3 3.3 進程控制進程控制進程控制進程控制OS如何管理和控制如何管理和控制進程程必必須知道知道進程的位置程的位置(依(依賴于所使用的存于所使用的存儲管管理方案)理方案)必必須知道知道進程的屬性程的屬性(PCB)必必須能能夠創(chuàng)建、撤建、撤銷進程程必必須能能夠改改變進程的狀程的狀態(tài)mxhl 進程控制的職責:l 進程的創(chuàng)建l 進程的撤消l 進程的阻塞與喚醒l 進程控制是通過執(zhí)行各種原語來實現(xiàn)的。3.3 3.3 3.3 3.3 進程控制進程控制進程控制進程控制mxh原原語是由若干條機器指令構成的、用于完是由若干條機器指令構成的、用于完成特定功能的一段程序。原成特定功能的一段程序。原語在在執(zhí)行行過程程中是不可分割的。(中是不可分割的。(P47)3.3 3.3 3.3 3.3 進程控制進程控制進程控制進程控制mxh3.3.3 3.3.3 3.3.3 3.3.3 進程的創(chuàng)建進程的創(chuàng)建進程的創(chuàng)建進程的創(chuàng)建進程圖進程圖引起創(chuàng)建進程的事件引起創(chuàng)建進程的事件進程的創(chuàng)建過程進程的創(chuàng)建過程123mxh3.3.3 3.3.3 3.3.3 3.3.3 進程的創(chuàng)建進程的創(chuàng)建進程的創(chuàng)建進程的創(chuàng)建A AB BC CD DE EI IJ JF FHHL LMMKKGGA AB BC CD DE EI IJ JF FHHL LMMKKGGmxh入口入口查查PCBPCB鏈表鏈表有空有空PCBPCB取空表取空表PCB(i)PCB(i)填填PCB(i)PCB(i)相應項相應項PCB(i)PCB(i)入就緒隊列入就緒隊列PCB(i)PCB(i)入進程家族入進程家族返回返回創(chuàng)建失敗創(chuàng)建失敗YNmxh進程創(chuàng)建進程創(chuàng)建進程創(chuàng)建進程創(chuàng)建#include#include pid_t fork(void);功能:創(chuàng)建一個新的進程。返回值:在子進程中為0,在父進程中為子進程ID,出錯為-1mxh進程創(chuàng)建進程創(chuàng)建進程創(chuàng)建進程創(chuàng)建該函數(shù)被調用一次,但返回兩次。兩次返回的區(qū)別是子進程的返回值是0,而父進程的返回值則是子進程的進程ID一般來說,在fork之后是父進程先執(zhí)行還是子進程先執(zhí)行是不確定的。這取決于內核所使用的調度算法。新創(chuàng)建的子進程是父進程的完全克隆完全克隆,會復制父進程的數(shù)據(jù)段、堆、??臻g(共享代碼段)。mxh進程相關術語進程相關術語進程相關術語進程相關術語init 進程領養(yǎng):當父進程在子進程結束前結束,子進程變成了孤兒進程,孤兒進程被init進程收養(yǎng),子進程的父進程就變成了init進程。僵尸進程當子進程在父進程結束前結束,如果父進程沒有釋放子進程的資源(默認),那么子進程就變成了一個僵尸進程。mxh進程創(chuàng)建進程創(chuàng)建進程創(chuàng)建進程創(chuàng)建mxh3.3.4 3.3.4 3.3.4 3.3.4 引起進程終止的事件引起進程終止的事件引起進程終止的事件引起進程終止的事件壽終:進程運行完自行退出壽終:進程運行完自行退出自殺:進程因錯誤而自行退出自殺:進程因錯誤而自行退出mxh3.3.2 3.3.2 3.3.2 3.3.2 引起進程終止的事件引起進程終止的事件引起進程終止的事件引起進程終止的事件他殺:進程被其它進程強行殺他殺:進程被其它進程強行殺死或由用戶殺死死或由用戶殺死處決:進程因異常而強行終結處決:進程因異常而強行終結mxh 檢索相應的PCB,讀其狀態(tài) 若處于執(zhí)行狀態(tài),則終止執(zhí)行 若有子孫進程則終止子孫進程 釋放終止進程的全部資源 將PCB從隊列中移出3.3.4 進程的終止過程mxh入口查進程鏈表有此PCB釋放該進程所占資源釋放該PCB結構本身返回出錯處理有子進程無有有無mxh3.3.3 3.3.3 3.3.3 3.3.3 進程的阻塞與喚醒進程的阻塞與喚醒進程的阻塞與喚醒進程的阻塞與喚醒1、引起進程阻塞的事件2、進程阻塞的過程3、進程喚醒的過程4、喚醒原語的執(zhí)行過程mxh引起進引起進程阻塞程阻塞的事件的事件啟動某種操作啟動某種操作請求系統(tǒng)服務請求系統(tǒng)服務新數(shù)據(jù)尚未到達新數(shù)據(jù)尚未到達無新工作可做無新工作可做mxh 執(zhí)行狀態(tài)的進程調用阻塞原語 進程變?yōu)樽枞麪顟B(tài) PCB進入阻塞隊列 轉進程調度程序,進行切換進程阻塞的過程mxh被阻塞進程期待的事件發(fā)生。由發(fā)現(xiàn)者進程調用喚醒原語 喚醒阻塞進程。阻塞進程進入就緒狀態(tài)。進程喚醒的過程mxh3.3 3.3 3.3 3.3 進程控制進程控制進程控制進程控制Linux進程控制原程控制原語:進程程創(chuàng)建建 fork進程程監(jiān)控控 ps進程程終止止 killmxh3.4 3.4 3.4 3.4 線程線程線程線程線程的引入程的引入進程:程:資源分配源分配單位和位和CPU調度度單位位缺點:缺點:時間空空間開開銷大,限制并大,限制并發(fā)度的提高度的提高將程序將程序塊的的執(zhí)行從行從進程中分離出來程中分離出來程序程序塊執(zhí)行需要行需要單獨的:獨的:執(zhí)行狀行狀態(tài):寄存器內容、:寄存器內容、棧、局部內存、局部內存程序程序塊執(zhí)行不需要行不需要單獨的:獨的:進程程資源:如文件、源:如文件、頁表內容等表內容等多多線程:將一個程序分成多個并程:將一個程序分成多個并發(fā)的活的活動(程(程序序塊)mxh3.4 3.4 3.4 3.4 線程線程線程線程進程程=線程程+資源集源集進程作程作為擁有有資源的基本源的基本單位,位,線程是系程是系統(tǒng)調度的基本度的基本單位。位。mxh3.4 3.4 3.4 3.4 線程線程線程線程進程和程和線程程資源所有源所有權(Process)調度的度的實體(體(Thread)mxh3.4 3.4 3.4 3.4 線程線程線程線程線程描述程描述線程狀程狀態(tài)(運行、就(運行、就緒、等待)、等待)一個一個執(zhí)行行棧未運行未運行時保存的保存的線程上下文、靜程上下文、靜態(tài)存存儲局部局部變量量對內存和其他內存和其他進程程資源的源的訪問與與該進程中其他程中其他線程共享程共享資源源mxh3.4 3.4 3.4 3.4 線程線程線程線程用用戶級線程程由由應用程序(用程序(線程程庫)實現(xiàn)線程管理(程管理(POSIX Pthreads、Win32 threads)內核感內核感覺不到不到線程的存在程的存在優(yōu)點點共享一個共享一個進程用程用戶空空間中,中,線程管理不需要內核模式的程管理不需要內核模式的切切換可運行任何可運行任何OS上,內核無需修改。上,內核無需修改。缺點缺點全阻塞全阻塞不能運用多不能運用多處理技理技術mxh3.4 3.4 3.4 3.4 線程線程線程線程用戶級線程用戶級線程mxh內核級線程(在處理機上被調度和執(zhí)行的對象)由內核實現(xiàn)線程管理克服了用戶級線程的缺點線程切換需要到內核的模式切換3.4 3.4 3.4 3.4 線程線程線程線程mxh內核級線程內核級線程3.4 3.4 3.4 3.4 線程線程線程線程mxh3.4 3.4 3.4 3.4 線程線程線程線程mxh程序、程序、進程、程、線程的比程的比較程序:程序:一一組有序指令的集合有序指令的集合進程:程:系系統(tǒng)分配分配資源的基本源的基本單位位線程:程:處理機理機調度的基本度的基本單位位3.4 3.4 3.4 3.4 線程線程線程線程mxh3.4 3.4 3.4 3.4 線程線程線程線程多多線程程編程程優(yōu)點:點:響響應程度高程度高資源共享源共享經(jīng)濟多多處理器體系理器體系結構利用構利用mxhmxhmxh3.5 3.5 3.5 3.5 處理器調度處理器調度處理器調度處理器調度請思考:我思考:我們是如何確定在任意是如何確定在任意時刻到刻到底哪個底哪個進程程執(zhí)行,哪個不行,哪個不執(zhí)行呢?行呢?進程管理的一個主要任程管理的一個主要任務就是就是選擇下一下一個要運行的個要運行的進程。程。mxh要解決的要解決的問題WHAT:按什么原按什么原則分配分配CPU-進程程調度算法度算法WHEN:何何時分配分配CPU-進程程調度度時機機HOW:如何分配:如何分配CPU-進程程調度方式度方式 3.5 3.5 3.5 3.5 處理器調度處理器調度處理器調度處理器調度mxhWHAT:WHAT:WHAT:WHAT:選擇進程調度算法的標準選擇進程調度算法的標準選擇進程調度算法的標準選擇進程調度算法的標準CPUCPU利用率利用率用用戶程序響程序響應時間系系統(tǒng)吞吐量吞吐量公平合理公平合理設備利用率利用率mxhWHEN:WHEN:WHEN:WHEN:進程調度時機進程調度時機進程調度時機進程調度時機時間片片過期期進程退出程退出進程阻塞程阻塞I/O中斷中斷發(fā)生生mxhHOW:HOW:HOW:HOW:進程調度方式進程調度方式進程調度方式進程調度方式 1.1.非搶占方式非搶占方式:簡單,實時性差簡單,實時性差 2.2.搶占方式搶占方式:(1 1)時間片原則)時間片原則(2 2)優(yōu)先權原則)優(yōu)先權原則(3 3)短作業(yè)優(yōu)先原則。)短作業(yè)優(yōu)先原則。mxh處理器調度的層次處理器調度的層次處理器調度的層次處理器調度的層次mxh(1 1)CPUCPU利用率利用率 CPUCPU利用率利用率=CPU=CPU有效工作有效工作時間/CPU/CPU總運行運行時間=CPU=CPU有效工作有效工作時間/(CPU/(CPU有效工作有效工作時間+CPU+CPU空空閑等待等待時間)(2 2)吞吐量(特)吞吐量(特別用于批用于批處理)理)使得使得單位位時間內內處理的作理的作業(yè)數(shù)盡可能多。數(shù)盡可能多。選擇調度算法的原則(面向系統(tǒng))mxh(3)周轉時間)周轉時間從作業(yè)提交給系統(tǒng)開始,到作業(yè)完成為止的時間間隔稱作作業(yè)周轉時間。作業(yè)周轉時間:作業(yè)周轉時間:ti=tf -ts 實際上,實際上,ti 是作業(yè)在系統(tǒng)里等待時間和運行是作業(yè)在系統(tǒng)里等待時間和運行時間之和。時間之和。平均作業(yè)周轉時間平均作業(yè)周轉時間:選擇調度算法的原則(面向用戶)mxh(4)響應時間)響應時間交互式進程從提交一個請求到接收到響交互式進程從提交一個請求到接收到響應之間的時間間隔。應之間的時間間隔。(5)公平性)公平性確保每個用戶每個進程獲得合理的CPU份額和其它資源份額,不會出現(xiàn)餓死的情況。選擇調度算法的原則選擇調度算法的原則(面向用戶面向用戶)mxh調度算法一調度算法一調度算法一調度算法一(FCFS)(FCFS)(FCFS)(FCFS)1 1、先來先服、先來先服務(First-come,first-served,FCFS)(First-come,first-served,FCFS)最先最先進入就入就緒進程首先分配到程首先分配到CPUCPU,F(xiàn)CFSFCFS策略可用策略可用FIFOFIFO隊列列實現(xiàn) 缺點:只缺點:只顧及到等候及到等候時間,沒有考,沒有考慮要求服要求服務時間長短。(不利于短作短。(不利于短作業(yè))mxh例例例例:如下一組進程如下一組進程如下一組進程如下一組進程P1P1P1P1、P2P2P2P2、P3P3P3P3,到達系統(tǒng)的先后順序分別如下,到達系統(tǒng)的先后順序分別如下,到達系統(tǒng)的先后順序分別如下,到達系統(tǒng)的先后順序分別如下面三圖所示,計算各種順序的平均周轉時間面三圖所示,計算各種順序的平均周轉時間面三圖所示,計算各種順序的平均周轉時間面三圖所示,計算各種順序的平均周轉時間進程到達時間運行時間P1028P219P323進程到達時間運行時間P209P1128P323進程到達時間運行時間P303P219P1228mxhP1P1P2P2P3P3T=(28+36+38)/3=T=(28+36+38)/3=3434P2P2P1P1P3P3T=(9+36+38)/3=T=(9+36+38)/3=27.627.6P3P3P2P2P1P1T=(3+11+38)/3=T=(3+11+38)/3=17.317.3可可見,F(xiàn)CFSFCFS算法的平均作算法的平均作業(yè)周周轉時間與作與作業(yè)提交及提交及調度的度的順序有關。序有關。mxh調度算法二調度算法二調度算法二調度算法二(SJF)(SJF)(SJF)(SJF)2 2、短作、短作業(yè)優(yōu)先(先(shortest-job-first,SJFshortest-job-first,SJF)以以進入系入系統(tǒng)的作的作業(yè)所要求的所要求的CPUCPU時間長短短為標準,準,總是是選取估取估計計算算時間最短的作最短的作業(yè)投投入運行。入運行。mxh進程名到達時間運行時間P106P208P307P403采用采用SJFSJF調度:調度:P4P4P1P1P3P3P2P2T=13msT=13ms采用采用FCFSFCFS調度:調度:P1P1P2P2P3P3P4P4T=16.25msT=16.25msmxhSJFSJFSJFSJF缺點:缺點:難以精確估以精確估計作作業(yè)所需所需CPUCPU時間,如程序,如程序員估估計過低,系低,系統(tǒng)可能提前可能提前終止止該作作業(yè)。忽忽視作作業(yè)等待等待時間,由于系,由于系統(tǒng)不斷接受新作不斷接受新作業(yè),而,而調度算法又度算法又總選計算算時間短的作短的作業(yè)投投入運行,因此,使入運行,因此,使進入系入系統(tǒng)時間早但早但計算算時間長的作的作業(yè)等待等待時間長,會出,會出現(xiàn)饑餓現(xiàn)象。象。mxh可搶占式可搶占式可搶占式可搶占式SJFSJFSJFSJF算法算法算法算法(SRTF)(SRTF)(SRTF)(SRTF)當一個新作當一個新作業(yè)到達就到達就緒隊列,如果新作列,如果新作業(yè)需需要的要的CPUCPU時間短,短,則強行趕走當前作行趕走當前作業(yè),這種算法也叫種算法也叫最短剩余最短剩余時間優(yōu)先算法先算法(shortest remaining time first,SRTFshortest remaining time first,SRTF)。)。mxh進程名到達時間運行時間P108P214P329P435SRTF:SRTF:P1P1P2P2P4P4P1P1P3P3T=13msT=13msSJF:SJF:P1P1P2P2P4P4P3P3T=14.25msT=14.25msmxh調度算法三調度算法三調度算法三調度算法三(HRRF)(HRRF)(HRRF)(HRRF)3 3、高響、高響應比比優(yōu)先先調度(度(Highest Response Ratio Highest Response Ratio First,HRRF)First,HRRF)FCFSFCFS和和SJFSJF都是比都是比較片面和片面和調度算法,度算法,F(xiàn)CFSFCFS只考只考慮作作業(yè)等候等候時間而忽而忽視了作了作業(yè)計算算時間,SJFSJF正好相反,本算法是一種折衷算法,正好相反,本算法是一種折衷算法,既考既考慮作作業(yè)等待等待時間,又考,又考慮作作業(yè)運行運行時間,這樣既照既照顧了短作了短作業(yè)又不使又不使長作作業(yè)等待等待時間過長,改,改進了了調度性能。度性能。mxhHRRFHRRFHRRFHRRF響響應比比=響響應時間/要求服要求服務時間 =(等待(等待時間+運行運行時間)/運行運行時間 =1+=1+等待等待時間/運行運行時間缺點:每次缺點:每次計算各道作算各道作業(yè)的響的響應比會有一比會有一定定時間開開銷,性能比,性能比SJFSJF略差。略差。mxh作業(yè)名到達時間運行時間P1020P2515P3105P41510SJF:SJF:P1P1P3P3P4P4P2P2T=25msT=25msFCFS:FCFS:P1P1P2P2P3P3P4P4T=28.75msT=28.75msHRRF:HRRF:P1P1P3P3P2P2P4P4T=26.25msT=26.25msmxh調度算法四調度算法四調度算法四調度算法四 優(yōu)先級調度算法優(yōu)先級調度算法優(yōu)先級調度算法優(yōu)先級調度算法優(yōu)優(yōu)先先級級可可以以通通過過內內部部或或外外部部方方式式來來定定義義。內內部部優(yōu)優(yōu)先先級級使使用用一一些些可可測測量量數(shù)數(shù)據(jù)據(jù)以以計計算算進進程程優(yōu)優(yōu)先先級級。外外部部優(yōu)優(yōu)先先級級是是通通過操作系統(tǒng)之外的準則來設置的。過操作系統(tǒng)之外的準則來設置的。優(yōu)優(yōu)先先級級調調度度可可以以是是可可搶搶占占的的或或者者非非搶搶占的占的。mxh靜態(tài)優(yōu)先級:創(chuàng)建進程時就確定,直到進程終止前都不靜態(tài)優(yōu)先級:創(chuàng)建進程時就確定,直到進程終止前都不改變。通常是一個整數(shù)。依據(jù):改變。通常是一個整數(shù)。依據(jù):進程類型(系統(tǒng)進程優(yōu)先級較高)進程類型(系統(tǒng)進程優(yōu)先級較高)對資源的需求(對對資源的需求(對CPUCPU和內存需求少的優(yōu)先級較高)和內存需求少的優(yōu)先級較高)用戶要求(緊迫程度和付費多少)用戶要求(緊迫程度和付費多少)動態(tài)優(yōu)先級:在創(chuàng)建進程時賦予優(yōu)先級,在進程運行過動態(tài)優(yōu)先級:在創(chuàng)建進程時賦予優(yōu)先級,在進程運行過程中可以自動改變,以后便獲得更好的調度性能。如:程中可以自動改變,以后便獲得更好的調度性能。如:在就緒隊列中等待時間延長則優(yōu)先級提高,使優(yōu)先級較低的進程在就緒隊列中等待時間延長則優(yōu)先級提高,使優(yōu)先級較低的進程在等待足夠了的時間后,其優(yōu)先級提高到可被調度執(zhí)行。在等待足夠了的時間后,其優(yōu)先級提高到可被調度執(zhí)行。進程每執(zhí)行一個時間片,就降低其優(yōu)先級。進程每執(zhí)行一個時間片,就降低其優(yōu)先級。mxh進程名進程名 到達到達時間時間運行運行時間時間優(yōu)先級優(yōu)先級P1P10 010103 3P2P20 01 11 1P3P30 02 24 4P4P40 01 15 5P5P50 05 52 2優(yōu)先級調度算法優(yōu)先級調度算法P2P2P5 P5 P1P1 P3P3 P4 P4T=12T=12mxh優(yōu)先級調度算法優(yōu)先級調度算法優(yōu)先級調度算法優(yōu)先級調度算法缺點:無缺點:無窮阻塞(阻塞(indefinite blockingindefinite blocking)或或饑餓(starvationstarvation)解決方案之一解決方案之一:老化老化在在19731973年關閉年關閉MITMIT的的IBM7094IBM7094時,發(fā)時,發(fā)現(xiàn)有一個低優(yōu)先級進程是于現(xiàn)有一個低優(yōu)先級進程是于19671967年年提交但是一直未運行提交但是一直未運行mxh調度算法五調度算法五調度算法五調度算法五(RR)(RR)(RR)(RR)4 4、輪轉法法調度(度(Round-robin,RRRound-robin,RR)系系統(tǒng)將所有的將所有的進程按先程按先進先出的原先出的原則排成一排成一個個隊列,將新來的列,將新來的進程加到就程加到就緒隊列的末尾,列的末尾,每當每當執(zhí)行行調度度時,調度程序從就度程序從就緒隊列中列中選第一個第一個進程,分配一個程,分配一個時間片,將片,將CPUCPU分配分配給進程,程,時間片一般片一般為10ms10ms100ms100ms。mxhRRRRRRRR進程需要程需要CPUCPU的的時間小于小于一個一個時間片的片的時間:進程本身會程本身會釋放放CPUCPU,進程程調度程序接著度程序接著處理就理就緒隊列的下一個列的下一個進程。程。進程所需程所需CPUCPU的的時間大于大于一個一個時間片的片的時間:定定時器會切斷當前器會切斷當前進程,程,進行上下文切行上下文切換,該進程被加到程被加到隊列尾部,接著列尾部,接著進程程調度程序度程序選擇就就緒隊列中的下一下列中的下一下進程。程。mxh進程名到達時間運行時間P1024P203P303RRRR(注:時間片為注:時間片為4ms)4ms)P1P1P2P2P3P3P1P1P1P1P1P1P1P1P1P1T=15.67msT=15.67msmxhRRRRRRRR如果如果時間片太小片太小,以至于大多數(shù),以至于大多數(shù)進程都不可程都不可能在一個能在一個時間片內運行完片內運行完畢,切,切換就會就會頻繁,繁,系系統(tǒng)開開銷顯著增大,所以,從系著增大,所以,從系統(tǒng)效率來看,效率來看,時間片取大一點好。片取大一點好。如果如果時間片片較大大,那么,隨著就,那么,隨著就緒隊列里列里進程數(shù)目的增加,程數(shù)目的增加,輪轉一次的一次的總時間增大,亦增大,亦即即對每個每個進程的響程的響應速度放慢了。速度放慢了。所以,所以,時間片大小的確定要從片大小的確定要從進程個數(shù),切程個數(shù),切換開開銷,系,系統(tǒng)效率和響效率和響應時間等多方面考等多方面考慮。mxh 例題:假如例題:假如5 5個就緒進程其到達系統(tǒng)和所需個就緒進程其到達系統(tǒng)和所需CPUCPU時間如下表所示時間如下表所示(單位:毫秒),如果忽略(單位:毫秒),如果忽略I/OI/O以及其他開銷分別計算采用以及其他開銷分別計算采用FCFSFCFS、非搶占式、非搶占式SJFSJF、搶占式、搶占式SJFSJF、HRRFHRRF調度算法進行調度算法進行CPUCPU調度調度的平均周轉時間。的平均周轉時間。進程到達和運行時間進程到達和運行時間進程進程到達時間到達時間運行時間運行時間A A0 03 3B B2 26 6C C4 44 4D D6 65 5E E8 82 2mxh 解答如下:解答如下:(1 1)采用)采用FCFSFCFS的調度順序為:的調度順序為:A AB BC CD DE E0 03 39 9131318182020平均周轉時間為:平均周轉時間為:T=(3-0)+(9-2)+(13-4)+(18-6)+(20-8)/5=8.6T=(3-0)+(9-2)+(13-4)+(18-6)+(20-8)/5=8.6帶權平均周轉時間為:帶權平均周轉時間為:W=2.56W=2.56mxh (2 2)采用非搶占)采用非搶占SJFSJF的調度順序為:的調度順序為:A AB BE EC CD D0 03 39 9111115152020平均周轉時間為:平均周轉時間為:T=7.6T=7.6帶權平均周轉時間為:帶權平均周轉時間為:W=1.84W=1.84mxh (3 3)采用搶占)采用搶占SJFSJF的調度順序為:的調度順序為:平均周轉時間為:平均周轉時間為:T=7.2T=7.2帶權平均周轉時間為:帶權平均周轉時間為:W=1.59W=1.59A AB1B1E EC CB2B20 03 38 8101015152020D D4 4mxh解答:解答:(4)HRRF算法:算法:在時刻在時刻0時進程時進程A就緒,此時,就緒,此時,CPU空閑,故空閑,故A運行,運行,到了時刻到了時刻2時進程時進程B就緒,進程就緒,進程A結束后,進程結束后,進程B進入運行,進入運行,接著進程接著進程C、D、E先后到達,進入就緒狀態(tài)。進程先后到達,進入就緒狀態(tài)。進程B運行結運行結束后,調度程序要從束后,調度程序要從C、D和和E中選擇一個投入運行,為此,中選擇一個投入運行,為此,計算它們的響應比:計算它們的響應比:RRc=9/4=2.25 RRd=8/5=1.60 RRe=3/2=1.50 因此,因此,C進程被選擇投入運行。進程運行進程被選擇投入運行。進程運行4個單位后結束個單位后結束mxh 進程進程C運行運行4個單位后結束,調度程序需要從個單位后結束,調度程序需要從D和和E進程挑進程挑選一個運行,為此,計算它們的響應比:選一個運行,為此,計算它們的響應比:RRd=12/5=2.40 RRe=7/2=3.5 因此,選擇因此,選擇E投入運行。綜上所述,進程的調度順序為:投入運行。綜上所述,進程的調度順序為:平均周轉時間為:平均周轉時間為:T=8.0 平均帶權周轉時間:平均帶權周轉時間:W=2.14A AB BC CE ED D0 03 39 9131315152020mxh調度算法六調度算法六調度算法六調度算法六(多級隊列調度多級隊列調度多級隊列調度多級隊列調度)mxh調度算法七調度算法七調度算法七調度算法七(多級反饋隊列調度多級反饋隊列調度多級反饋隊列調度多級反饋隊列調度)mxh調度算法七調度算法七調度算法七調度算法七(多級反饋隊列調度多級反饋隊列調度多級反饋隊列調度多級反饋隊列調度)特點:長、短作業(yè)兼顧,有較好的響特點:長、短作業(yè)兼顧,有較好的響 應時間應時間(1 1)短作業(yè)一次完成;)短作業(yè)一次完成;(2 2)中型作業(yè)周轉時間不長;)中型作業(yè)周轉時間不長;(3 3)大型作業(yè)不會長期不處理。)大型作業(yè)不會長期不處理。mxh重點概念和內容提示重點概念和內容提示重點概念和內容提示重點概念和內容提示常用進程調度算法常用進程調度算法進程的概念、進程與程序的區(qū)別進程的概念、進程與程序的區(qū)別進程的結構、狀態(tài)及轉換進程的結構、狀態(tài)及轉換
展開閱讀全文
溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
提示  裝配圖網(wǎng)所有資源均是用戶自行上傳分享,僅供網(wǎng)友學習交流,未經(jīng)上傳用戶書面授權,請勿作他用。
關于本文
本文標題:第3章 處理器管理
鏈接地址:http://www.hcyjhs8.com/article/239608223.html

相關資源

更多
正為您匹配相似的精品文檔
關于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對上載內容本身不做任何修改或編輯。若文檔所含內容侵犯了您的版權或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!