最全計算機操作系統(tǒng)期末復習課件_第1頁
最全計算機操作系統(tǒng)期末復習課件_第2頁
最全計算機操作系統(tǒng)期末復習課件_第3頁
最全計算機操作系統(tǒng)期末復習課件_第4頁
最全計算機操作系統(tǒng)期末復習課件_第5頁
已閱讀5頁,還剩195頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

計算機操作系統(tǒng)復習

2022年11月25日1計算機操作系統(tǒng)復習

2022年11月22日1標題添加點擊此處輸入相關(guān)文本內(nèi)容點擊此處輸入相關(guān)文本內(nèi)容前言點擊此處輸入相關(guān)文本內(nèi)容標題添加點擊此處輸入相關(guān)文本內(nèi)容2標題添加點擊此處輸入相點擊此處輸入前言點擊此處輸入標題添加點課程主要內(nèi)容教材內(nèi)容操作系統(tǒng)引論(第1章)進程管理(第2章)處理機調(diào)度與死鎖(第3章)存儲管理(第4章)設(shè)備管理(第5章)文件管理(第6章)UNIX系統(tǒng)內(nèi)核結(jié)構(gòu)(第10章)3課程主要內(nèi)容教材內(nèi)容3計算題類型總結(jié)利用信號量實現(xiàn)進程同步處理機調(diào)度算法(周轉(zhuǎn)時間)銀行家算法分區(qū)存儲管理算法邏輯地址物理地址變換請求分頁中的頁面置換算法磁盤訪問時間磁盤調(diào)度算法(平均移道數(shù))混合索引分配文件控制塊和索引結(jié)點位示圖4計算題類型總結(jié)利用信號量實現(xiàn)進程同步4第一章操作系統(tǒng)引論

5第一章操作系統(tǒng)引論

51.3操作系統(tǒng)的基本特征并發(fā)性(Concurrence)共享性(Sharing)虛擬性(Virtual)異步性(Asynchronism)基本特征:最重要特性,其它三種特性以此為前提。61.3操作系統(tǒng)的基本特征并發(fā)性(Concurrence)操作系統(tǒng)的形成單道批處理系統(tǒng)多道批處理系統(tǒng)操作系統(tǒng)的形成在多道程序系統(tǒng)中增設(shè)一組軟件以有效加以解決,同時增設(shè)方便用戶使用計算機的軟件,這樣便形成了操作系統(tǒng)。操作系統(tǒng):是一組控制和管理計算機硬件和軟件資源,合理地對各類作業(yè)進行調(diào)度,以及方便用戶使用的程序集合。7操作系統(tǒng)的形成單道批處理系統(tǒng)操作系統(tǒng):是一組控制和管理計算機操作系統(tǒng)的結(jié)構(gòu)設(shè)計傳統(tǒng)的操作系統(tǒng)結(jié)構(gòu)無結(jié)構(gòu)操作系統(tǒng)模塊化OS結(jié)構(gòu)分層式OS結(jié)構(gòu)現(xiàn)代操作系統(tǒng)結(jié)構(gòu)微內(nèi)核的OS結(jié)構(gòu):將客戶/服務(wù)器技術(shù)、面向?qū)ο蠹夹g(shù)用于OS中所形成的OS結(jié)構(gòu)。8操作系統(tǒng)的結(jié)構(gòu)設(shè)計傳統(tǒng)的操作系統(tǒng)結(jié)構(gòu)8第二章進程管理

9第二章進程管理

92、進程process的基本特征

(1)結(jié)構(gòu)特征從結(jié)構(gòu)上看,每個進程(進程實體)都是由程序段、數(shù)據(jù)段及進程控制塊(PCB)組成。

(2)動態(tài)性

進程的實質(zhì)是程序在處理機上的一次執(zhí)行過程,因此是動態(tài)性的。所以動態(tài)性是進程的最基本的特征。同時動態(tài)性還表現(xiàn)在進程則是有生命期的,它因創(chuàng)建而產(chǎn)生,因調(diào)度而執(zhí)行,因得不到資源而暫停,因撤消而消亡。進程的定義、特征102、進程process的基本特征進程的定義、特征10

進程在運行期間并非固定處于某個狀態(tài),而是不斷從一個狀態(tài)轉(zhuǎn)換到另一個狀態(tài)。二、進程狀態(tài)2、進程狀態(tài)轉(zhuǎn)換11進程在運行期間并非固定處于某個狀態(tài),而是不斷從一個狀態(tài)轉(zhuǎn)換具有掛起狀態(tài)的進程狀態(tài)活動就緒執(zhí)行掛起調(diào)度時間片完活動阻塞事件發(fā)生等待事件靜止就緒靜止阻塞激活掛起事件發(fā)生激活掛起12具有掛起狀態(tài)的進程狀態(tài)活動就緒執(zhí)行掛起調(diào)度時間片完活動阻塞事線程的基本概念進程是資源分配的單位,而線程是處理機調(diào)度的單位。一個進程可以創(chuàng)建一個或多個線程。多個線程會爭奪CPU,在不同的狀態(tài)之間進行轉(zhuǎn)換。線程也是一個動態(tài)的概念,也有一個從創(chuàng)建到消亡的生命過程,具多種狀態(tài)。同一進程中的所有線程都具有相同的地址空間(進程的地址空間)。13線程的基本概念進程是資源分配的單位,而線程是處理機調(diào)度的單位線程的實現(xiàn)方式

線程的實現(xiàn)方式內(nèi)核支持線程的實現(xiàn)直接利用系統(tǒng)調(diào)用進行線程控制。用戶級線程的實現(xiàn)不能直接利用系統(tǒng)調(diào)用。為了取得內(nèi)核的服務(wù)(獲得系統(tǒng)資源),需要借助中間系統(tǒng)(運行時系統(tǒng)、輕型進程)。14線程的實現(xiàn)方式線程的實現(xiàn)方式14同步機制應(yīng)遵循的規(guī)則空閑讓進:當無進程處于臨界區(qū)時,表明臨界資源處于空閑狀態(tài),應(yīng)允許一個請求進入臨界區(qū)的進程立即進入自己的臨界區(qū),以有效地利用臨界資源。忙則等待:當已有進程進入臨界區(qū)時,表明臨界資源正在被訪問,因而其他試圖進入臨界區(qū)的進程必須等待,以保證對臨界資源的互斥訪問。有限等待:對要求訪問臨界資源的進程,應(yīng)保證在有限時間內(nèi)能進入自己的臨界區(qū),以免陷入死等狀態(tài)。讓權(quán)等待:當進程不能進入自己的臨界區(qū)時,應(yīng)立即釋放處理機,以免進程陷入忙等。15同步機制應(yīng)遵循的規(guī)則空閑讓進:當無進程處于臨界區(qū)時,表明臨界信號量機制信號量機制信號量用于表示資源數(shù)目或請求使用某一資源的進程個數(shù)的整型量。整型信號量記錄型信號量信號量集(AND信號量集、一般信號量集)16信號量機制信號量機制16利用信號量實現(xiàn)進程同步例:進程A與進程B共享同一文件file,設(shè)此文件要求互斥使用,則可將file作為臨界資源,有關(guān)file的使用程序段分別為臨界區(qū)CSA和CSB。

semaphoremutex=1;PA:{ L1:P(mutex); CSA;

V(mutex);

remainderofprocessA; GOTOL1;}PB:{ L2:P(mutex); CSB;

V(mutex); remainderofprocessB;GOTOL2;}

17利用信號量實現(xiàn)進程同步例:進程A與進程B共享同一文件fileS1S3S2S4S5S6S7S8例:利用信號量來描述前趨圖關(guān)系利用信號量實現(xiàn)進程同步18S1S3S2S4S5S6S7S8例:利用信號量來描述前趨圖關(guān)

具有8個結(jié)點的前趨圖。圖中的前趨圖中共有10條有向邊,可設(shè)10個信號量,初值均為0;有8個結(jié)點,可設(shè)計成8個并發(fā)進程,具體描述如下:S1S3S2S4S5S6S7S8agefbcdhij利用信號量實現(xiàn)進程同步19具有8個結(jié)點的前趨圖。圖中的前趨圖中共有10條有向邊Structsmaphorea,b,c,d,e,f,g,h,i,j=0,0,0,0,0,0,0,0,0,0cobegin{S1;V(a);V(b);V(c);}{P(a);S2;V(d);}{P(b);S3;V(e);V(f);}{P(c);S4;V(g);}{P(d);P(e);S5;V(h);}{P(f);P(g);S6;V(i)}{P(h);P(i);S7;V(j);}{P(j);S8;}coendS1S3S2S4S5S6S7S8agefbcdhij利用信號量實現(xiàn)進程同步20Structsmaphorea,b,c,d,e,f,g,2.4經(jīng)典進程的同步問題

在多道程序環(huán)境下,進程同步問題十分重要,出現(xiàn)一系列經(jīng)典的進程同步問題,其中有代表性有:生產(chǎn)者—消費者問題哲學家進餐問題讀者—寫者問題其他同步問題212.4經(jīng)典進程的同步問題在多道程序“哲學家進餐”問題問題描述:有五個哲學家,他們的生活方式是交替地進行思考和進餐。他們共用一張圓桌,分別坐在五張椅子上。在圓桌上有五個碗和五支筷子,平時一個哲學家進行思考,饑餓時便試圖取用其左、右最靠近他的筷子,只有在他拿到兩支筷子時才能進餐。進餐畢,放下筷子又繼續(xù)思考。解決死鎖問題的例子22“哲學家進餐”問題問題描述:解決死鎖問題的例子22哲學家進餐問題的改進解法方法一:至多只允許四位哲學家同時去拿左筷子,最終能保證至少有一位哲學家能進餐,并在用完后釋放兩只筷子供他人使用。方法二:僅當哲學家的左右手筷子都拿起時才允許進餐。方法三:規(guī)定奇數(shù)號哲學家先拿左筷子再拿右筷子,而偶數(shù)號哲學家相反。23哲學家進餐問題的改進解法方法一:至多只允許四位哲學家同時去拿哲學家進餐問題的改進解法方法一:至多只允許四位哲學家同時去拿左筷子,最終能保證至少有一位哲學家能進餐,并在用完后釋放兩只筷子供他人使用。設(shè)置一個初值為4的信號量r,只允許4個哲學家同時去拿左筷子,這樣就能保證至少有一個哲學家可以就餐,不會出現(xiàn)餓死和死鎖的現(xiàn)象。原理:至多只允許四個哲學家同時進餐,以保證至少有一個哲學家能夠進餐,最終總會釋放出他所使用過的兩支筷子,從而可使更多的哲學家進餐。24哲學家進餐問題的改進解法方法一:至多只允許四位哲學家同時去拿哲學家進餐問題的改進解法semaphorechopstick[5]={1,1,1,1,1};semaphorer=4;voidphilosopher(inti){while(true){think();wait(r);//請求進餐wait(chopstick[i]);//請求左手邊的筷子wait(chopstick[(i+1)mod5]);//請求右手邊的筷子eat();signal(chopstick[(i+1)mod5]);//釋放右手邊的筷子signal(chopstick[i]);//釋放左手邊的筷子signal(r);//釋放信號量rthink();}}25哲學家進餐問題的改進解法semaphorechopstic哲學家進餐問題的改進解法方法二:僅當哲學家的左右手筷子都拿起時才允許進餐。解法1:利用AND型信號量機制實現(xiàn)。原理:多個臨界資源,要么全部分配,要么一個都不分配,因此不會出現(xiàn)死鎖的情形。26哲學家進餐問題的改進解法方法二:僅當哲學家的左右手筷子都拿起哲學家進餐問題的改進解法semaphorechopstick[5]={1,1,1,1,1};voidphilosopher(inti){while(true){think();Swait(chopstick[i];chopstick[(i+1)mod5]);eat();Ssignal(chopstick[(i+1)mod5];chopstick[i]);think();}}27哲學家進餐問題的改進解法semaphorechopstic哲學家進餐問題的改進解法方法二:僅當哲學家的左右手筷子都拿起時才允許進餐。解法2:利用信號量的保護機制實現(xiàn)。原理:通過互斥信號量mutex對eat()之前取左側(cè)和右側(cè)筷子的操作進行保護,可以防止死鎖的出現(xiàn)。28哲學家進餐問題的改進解法方法二:僅當哲學家的左右手筷子都拿起哲學家進餐問題的改進解法semaphoremutex=1;semaphorechopstick[5]={1,1,1,1,1};voidphilosopher(inti){while(true){think();wait(mutex);wait(chopstick[i]);wait(chopstick[(i+1)mod5]);signal(mutex);eat();signal(chopstick[(i+1)mod5]);signal(chopstick[i]);think();

}}29哲學家進餐問題的改進解法semaphoremutex=哲學家進餐問題的改進解法方法三:規(guī)定奇數(shù)號哲學家先拿左筷子再拿右筷子,而偶數(shù)號哲學家相反。原理:按照下圖,將是2,3號哲學家競爭3號筷子,4,5號哲學家競爭5號筷子。1號哲學家不需要競爭。最后總會有一個哲學家能獲得兩支筷子而進餐。先申請的哲學家會較先可以吃飯并釋放筷子,因此不會出現(xiàn)餓死的哲學家。122133445530哲學家進餐問題的改進解法方法三:規(guī)定奇數(shù)號哲學家先拿左筷子再哲學家進餐問題的改進解法semaphorechopstick[5]={1,1,1,1,1};voidphilosopher(inti){while(true){if(imod2==0)//偶數(shù)哲學家,先右后左。{wait(chopstick[(i+1)mod5]);wait(chopstick[i]);eat();signal(chopstick[i]);signal(chopstick[(i+1)mod5]);}Else//奇數(shù)哲學家,先左后右。{wait(chopstick[i]);wait(chopstick[(i+1)mod5]);eat();signal(chopstick[(i+1)mod5]);signal(chopstick[i]);}}}31哲學家進餐問題的改進解法semaphorechopstic第三章處理機調(diào)度與死鎖

32第三章處理機調(diào)度與死鎖

32提交作業(yè)調(diào)度作業(yè)調(diào)度作業(yè)狀態(tài)轉(zhuǎn)換圖后備退出完成一、調(diào)度的層次就緒阻塞就緒阻塞運行交換調(diào)度進程調(diào)度(線程調(diào)度)33提交作業(yè)調(diào)度作業(yè)調(diào)度作業(yè)狀態(tài)轉(zhuǎn)換圖后備退出完成一、調(diào)度的層次FCFS例題例:下面三個作業(yè)幾乎同時到達系統(tǒng)并立即進行FCFS調(diào)度:作業(yè)名所需CPU時間作業(yè)128作業(yè)210作業(yè)31假設(shè)提交順序為1、2、3,則平均作業(yè)周轉(zhuǎn)時間T=若提交順序改為作業(yè)2、1、3,則T=若提交順序改為作業(yè)3、2、1,則T=由此可以看出,F(xiàn)CFS調(diào)度算法的平均作業(yè)周轉(zhuǎn)時間與作業(yè)提交的順序有關(guān)。(28+38+39)/3=35(10+38+39)/3=29(1+11+39)/3=1734FCFS例題例:下面三個作業(yè)幾乎同時到達系統(tǒng)并立即進行FCF進程調(diào)度算法先來先服務(wù)FCFS例1:進程名到達時間服務(wù)時間A01B1100C

2

1D3

10035進程調(diào)度算法先來先服務(wù)FCFS35周轉(zhuǎn)時間服務(wù)時間完成時間-到達時間開始時間+服務(wù)時間上一個進程的完成時間1 101 1001101 102100100102 2021991.9936周轉(zhuǎn)時間服務(wù)時間完成時間-到達時間開始時間+服務(wù)時間上一個進執(zhí)行順序:SJF/SPF(非搶占式)A033103ABCDE24686452B3971.1791131.51115112.751520142.8ECD7.61.84周轉(zhuǎn)時間=結(jié)束時間-到達時間帶權(quán)周轉(zhuǎn)時間=周轉(zhuǎn)/服務(wù)37執(zhí)行順序:SJF/SPF(非搶占式)A033103ABCDE基本思想:多級反饋隊列調(diào)度算法是時間片輪轉(zhuǎn)算法和優(yōu)先級調(diào)度算法的綜合和發(fā)展,通過動態(tài)調(diào)整進程優(yōu)先級和時間片大小,不必事先估計進程的執(zhí)行時間。多級反饋隊列可兼顧多方面的系統(tǒng)目標,是目前公認的一種較好的進程調(diào)度算法。FCFS+優(yōu)先級+RR+搶占七、多級反饋隊列調(diào)度算法38基本思想:七、多級反饋隊列調(diào)度算法38七、多級反饋隊列調(diào)度算法---實現(xiàn)思想(1)設(shè)置多個就緒隊列,并為每個隊列賦予不同的優(yōu)先級。隊列1的優(yōu)先級最高,其余隊列逐個降低。(2)每個隊列中進程執(zhí)行時間片的大小也各不相同,進程所在隊列的優(yōu)先級越高,其相應(yīng)的時間片就越短。(3)當一個新進程進入系統(tǒng)時,首先將它放入隊列1的末尾,按FCFS等待調(diào)度。如能完成,便可準備撤離系統(tǒng),反之由調(diào)度程序?qū)⑵滢D(zhuǎn)入隊列2的末尾,按FCFS再次等待調(diào)度,如此下去,最后進入隊列n按RR算法調(diào)度執(zhí)行。(4)僅當隊列1為空時,才調(diào)度隊列2中的進程運行。若一個隊列中的進程正執(zhí)行,此時有新進程進入優(yōu)先級較高的隊列中,則新進程將搶占運行,原進程轉(zhuǎn)移至本隊列隊尾。39七、多級反饋隊列調(diào)度算法---實現(xiàn)思想(1)設(shè)置多個就緒隊列二、產(chǎn)生死鎖的原因競爭資源進程間推進順序非法三、產(chǎn)生死鎖的必要條件

互斥條件(mutualexclusion)請求和保持條件(hold-while-applying)不剝奪條件(nonpreemption)環(huán)路等待條件(circularwait)40二、產(chǎn)生死鎖的原因競爭資源三、產(chǎn)生死鎖的必要條件四、處理死鎖的基本方法目前處理死鎖的基本方法有:預防死鎖:通過設(shè)置某些限制條件,去破壞產(chǎn)生死鎖的四個必要條件中的一個或幾個條件,來防止死鎖的發(fā)生。避免死鎖:在資源的動態(tài)分配過程中,用某種方法去防止系統(tǒng)進入不安全狀態(tài),從而避免死鎖的發(fā)生。檢測死鎖:允許系統(tǒng)在運行過程中發(fā)生死鎖,但可設(shè)置檢測機構(gòu)及時檢測死鎖的發(fā)生,并采取適當措施加以清除。解除死鎖:當檢測出死鎖后,便采取適當措施將進程從死鎖狀態(tài)中解脫出來。銀行家算法41四、處理死鎖的基本方法目前處理死鎖的基本方法有:銀行家算法4銀行家算法假定系統(tǒng)中有5個進程P0到P4,3類資源及數(shù)量分別為A(10個),B(5個),C(7個),T0時刻的資源分配情況如下

表1T0時刻的資源分配表42銀行家算法假定系統(tǒng)中有5個進程P0到P4,3類資源及數(shù)量分(1)T0時刻的安全性利用安全性算法對T0時刻的資源分配情況進行分析:T0時刻存在著一個安全序列{P1,P3,P4,P2,P0},故系統(tǒng)是安全的。表2T0時刻的安全性檢查表532true332532743true743745true745104710471057truetrue332ABCAvailable43(1)T0時刻的安全性T0時刻存在著一個安全序列{P1,P(2)

P1請求資源Request1(1,0,2)

P1發(fā)出請求向量Request1(1,0,2),已知Need1(1,2,2),Available(3,3,2),系統(tǒng)按銀行家算法進行檢查:1)Request1(1,0,2)≤Need1(1,2,2)2)Request1(1,0,2)≤Available(3,3,2)3)系統(tǒng)試為P1分配資源,并修改相應(yīng)的向量Available、Need、Allocation44(2)P1請求資源Request1(1,0,2)P1P1請求資源Request1(1,0,2)時的資源分配表(302)(020)(230)45P1請求資源Request1(1,0,2)時的資源分配表(3由安全性檢查分析得知:此時刻存在著一個安全序列{P1,P3,P4,P2,P0},故系統(tǒng)是安全的,可以立即將P1所申請的資源分配給它。4)利用安全性算法檢查資源分配后此時系統(tǒng)是否安全P1請求資源Request1(1,0,2)時的安全性檢查表230532true532743true743745true7451047true10471057true46由安全性檢查分析得知:此時刻存在著一個安全序列{P1(3)P4請求資源Request4(3,3,0)

P4發(fā)出請求向量Request4(3,3,0),系統(tǒng)按銀行家算法進行檢查:1)Request4(3,3,0)≤Need4(4,3,1)2)Request4(3,3,0)>Available(2,3,0),表示資源不夠,則讓P4等待47(3)P4請求資源Request4(3,3,0)P4發(fā)出(4)P0請求資源Request0(0,2,0)

P0發(fā)出請求向量Request0(0,2,0),系統(tǒng)按銀行家算法進行檢查:1)Request0(0,2,0)≤Need0(7,4,3)2)Request0(0,2,0)≤Available(2,3,0)3)系統(tǒng)試為P0分配資源,并修改相應(yīng)的向量。48(4)P0請求資源Request0(0,2,0)P0發(fā)表5P0請求資源Request0(0,2,0)時的資源分配表[210][030][723]

4)進行安全性檢查資源分配后此時系統(tǒng)是否安全,因Avaliable(2,1,0)已不能滿足任何進程需要,故系統(tǒng)進入不安全狀態(tài),此時系統(tǒng)不分配資源。49表5P0請求資源Request0(0,2,0)時的資源分第四章存儲管理

50第四章存儲管理

504.2連續(xù)分配存儲管理方式連續(xù)分配方式(分區(qū)技術(shù)):指為一個用戶程序分配一片連續(xù)的內(nèi)存空間。

單一連續(xù)分區(qū)分配(靜態(tài)分區(qū)技術(shù)):僅用于單用戶單任務(wù)系統(tǒng)固定分區(qū)分配(靜態(tài)分區(qū)技術(shù)):可用于多道系統(tǒng)可變分區(qū)分配(動態(tài)分區(qū)技術(shù))可重定位可變分區(qū)分配(動態(tài)分區(qū)技術(shù)):引入了動態(tài)重定位和內(nèi)存緊湊技術(shù)伙伴系統(tǒng)(動態(tài)分區(qū)技術(shù))靜態(tài)分區(qū):作業(yè)裝入時一次完成,分區(qū)大小及邊界在運行時不能改變。動態(tài)分區(qū):根據(jù)作業(yè)大小動態(tài)地建立分區(qū),分區(qū)的大小、數(shù)目可變。514.2連續(xù)分配存儲管理方式連續(xù)分配方式(分區(qū)技術(shù)):指為2、分區(qū)分配算法為了將一個作業(yè)裝入內(nèi)存,應(yīng)按照一定的分配算法從空閑分區(qū)表(鏈)中選出一個滿足作業(yè)需求的分區(qū)分配給作業(yè)。目前常用分配算法有:首次適應(yīng)算法(First-Fit)循環(huán)首次適應(yīng)算法(Next-Fit)最佳適應(yīng)算法(Best-Fit)最壞適應(yīng)算法(Worst-Fit)按地址遞增的次序排列。按容量大小遞增的次序排列。按容量大小遞減的次序排列。522、分區(qū)分配算法為了將一個作業(yè)裝入內(nèi)存,應(yīng)按照一定的分配算法4.3基本分頁存儲管理方式基本分頁存儲管理方式在分頁存儲管理方式中,如果不具備頁面對換功能,不支持虛擬存儲器功能,這種存儲管理方式稱為純分頁或基本分頁存儲管理方式。在調(diào)度作業(yè)運行時,必須將它的所有頁面一次調(diào)入內(nèi)存,但邏輯上連續(xù)的各個頁所對應(yīng)的內(nèi)存塊可以不連續(xù)。特殊的固定分區(qū)+離散分配534.3基本分頁存儲管理方式基本分頁存儲管理方式53三、地址結(jié)構(gòu)邏輯地址:例:地址長為32位,其中0-11位為頁內(nèi)地址,即每頁的大小為212=4KB;12-31位為頁號,地址空間最多允許有220=1M頁。物理地址:例:地址長為22位,其中0-11位為塊內(nèi)地址,即每塊的大小為212=4KB,與頁相等;12-21位為塊號,內(nèi)存地址空間最多允許有210=1K塊。

3112110頁號p位移量w2112110塊號b塊內(nèi)位移d54三、地址結(jié)構(gòu)邏輯地址:31

給定一個邏輯地址空間中的地址為A,頁面的大小為L,則頁號P和頁內(nèi)地址d可按下式求得:

其中,INT是整除函數(shù),mod是取余函數(shù)。例如,系統(tǒng)的頁面大小為1KB,設(shè)A=2170B,則由上式可以求得P=2,d=122。

已知邏輯地址求頁號和頁內(nèi)地址頁從0開始編號三、地址結(jié)構(gòu)55給定一個邏輯地址空間中的地址為A,頁面的大小為L,則頁號三、地址結(jié)構(gòu)例題例:設(shè)有一頁式存儲管理系統(tǒng),向用戶提供的邏輯地址空間最大為16頁,每頁2048B,內(nèi)存總共有8個存儲塊,試問邏輯地址至少應(yīng)為多少位?內(nèi)存空間有多大?解:(1)頁式存儲管理系統(tǒng)的邏輯地址為:其中頁內(nèi)地址表每頁的大小即2048B=2*1024B=211B,所以頁內(nèi)地址為11位;頁號表最多允許的頁數(shù)即16頁=24頁,所以頁號為4位。故邏輯地址至少應(yīng)為15位。(2)物理地址為:其中塊內(nèi)地址表每塊的大小與頁大小相等,所以塊內(nèi)地址也為11位;其中塊號表內(nèi)存空間最多允許的塊數(shù)即8塊=23塊,所以塊號為3位。故內(nèi)存空間至少應(yīng)為14位,即214=16KB。56三、地址結(jié)構(gòu)例題例:設(shè)有一頁式存儲管理系統(tǒng),向用戶提供的邏輯四、地址變換例題例1:若在一分頁存儲管理系統(tǒng)中,某作業(yè)的頁表如下表所示,已知頁面大小為1024B,試將十進制邏輯地址1011,2148,5012轉(zhuǎn)化為相應(yīng)的物理地址。57四、地址變換例題例1:若在一分頁存儲管理系統(tǒng)中,某作業(yè)的頁表四、地址變換例題解:設(shè)頁號為P,頁內(nèi)位移為W,邏輯地址為A,內(nèi)存地址為M,頁面大小為L,則P=int(A/L)W=AmodL對于邏輯地址1011P=int(1011/1024)=0W=1011mod1024=1011A=1011=(0,1011)查頁表第0頁在第2塊,所以物理地址為M=1024*2+1011=3059。58四、地址變換例題解:設(shè)頁號為P,頁內(nèi)位移為W,邏輯地址為A,四、地址變換例題對于邏輯地址為2148P=int(2148/1024)=2W=2148mod1024=100A=2148=(2,100)查頁表第2頁在第1塊,所以物理地址為M=1024*1+100=1124。對于邏輯地址5012P=int(5012/1024)=4W=5012mod1024=916因頁號超過頁表長度,該邏輯地址非法。59四、地址變換例題對于邏輯地址為214859有效訪問內(nèi)存的時間

T=PTLB*(TTLB+TM)+(1-PTLB

)*(TTLB+2TM

)其中,PTLB為快表的命中率,TTLB為快表的訪問時間,TM為內(nèi)存的訪問時間具有快表的地址變換機構(gòu)938220頁表長度頁表始址45224528823120+<頁表寄存器邏輯地址物理地址越界中斷頁合法頁表快表TTLB:訪問快表但沒有命中2TM:分別訪問頁表和數(shù)據(jù)60有效訪問內(nèi)存的時間具有快表的地址變換機構(gòu)938220頁表長度例:

有一頁式系統(tǒng),其頁表存放在主存中。(1)如果對主存的一次存取需要100ns,試問實現(xiàn)一次頁面訪問的存取時間是多少?(2)如果系統(tǒng)加有快表,對快表的一次存取需要20ns,若平均命中率為85%,試問此時的存取時間為多少?解:(1)頁表放主存中,則實現(xiàn)一次頁面訪問需2次訪問主存,一次是訪問頁表,確定所存取頁面的物理塊,從而得到其物理地址,一次根據(jù)物理地址存取頁面數(shù)據(jù)。所以實現(xiàn)一次頁面訪問的存取時間為:100ns*2=200ns(2)系統(tǒng)有快表,則實現(xiàn)一次頁面訪問的存取時間為:

0.85*(20ns+100ns)+(1-0.85)*(20ns+2*100ns)=135ns

有效內(nèi)存訪問時間例題61例:有一頁式系統(tǒng),其頁表存放在主存中。有效內(nèi)存訪問時間例題在為作業(yè)分配內(nèi)存時以段為單位,分配一段連續(xù)的物理地址空間;段間不必連續(xù)。作業(yè)的邏輯地址空間是二維的,其邏輯地址由段號和段內(nèi)地址組成。地址映射需要CPU的硬件支持(地址變換機構(gòu))注:內(nèi)存分配分頁管理中,邏輯地址是線性地址(一維)。分段管理中,段號S和段內(nèi)位移d不能形成一個線性地址,因為它實際上是代表著段長和段內(nèi)位移兩個變量。由于這兩個變量沒有特定的限制范圍而無法用一個變量來替代,因此分段管理的邏輯地址是二維地址。62在為作業(yè)分配內(nèi)存時以段為單位,分配一段連續(xù)的物理地址空間;段例1、在一個段式存儲管理系統(tǒng)中,其段表為:段號內(nèi)存起始地址段長02105001235020210090313505904193895試求右表中邏輯地址對應(yīng)的物理地址是什么?解:邏輯地址為:邏輯地址對應(yīng)的物理地址為:210+430=640。邏輯地址因為段內(nèi)地址120>段長90,所以該段為非法段。分段地址變換例題63例1、在一個段式存儲管理系統(tǒng)中,其段表為:分段地址變換例題6分頁和分段的主要區(qū)別二者優(yōu)點的結(jié)合----段頁式存儲管理64分頁和分段的主要區(qū)別二者優(yōu)點的結(jié)合----段頁式存儲管理64存儲管理策略分類存儲管理:實存管理分區(qū)(Partitioning)(連續(xù)分配方式)(包括固定分區(qū)、可變分區(qū)和伙伴系統(tǒng))分頁(Paging)分段(Segmentation)段頁式(Segmentationwithpaging)虛存管理請求分頁(Demandpaging)--主流技術(shù)請求分段(Demandsegmentation)請求段頁式(DemandSWP)離散分配65存儲管理策略分類存儲管理:離散分配65虛擬存儲器的概念虛擬存儲技術(shù)的種類請求分頁請求分段請求段頁式速度和容量虛擬存儲量的擴大是以犧牲CPU工作時間以及內(nèi)外存交換時間為代價。虛擬存儲器的容量取決于主存與輔存的容量,最大容量是由計算機的地址結(jié)構(gòu)決定。虛擬存儲器的邏輯地址空間理論上不受物理存儲器的限制。如32位機器,虛擬存儲器的最大容量就是4G,再大CPU無法直接訪問。66虛擬存儲器的概念虛擬存儲技術(shù)的種類66二、虛擬存儲器的實現(xiàn)方法1、分頁請求系統(tǒng)在分頁系統(tǒng)的基礎(chǔ)上,增加了請求調(diào)頁功能、頁面置換功能所形成的頁式虛擬存儲器系統(tǒng)。它允許只裝入若干頁的用戶程序和數(shù)據(jù),便可啟動運行,以后在硬件支持下通過調(diào)頁功能和置換頁功能,陸續(xù)將要運行的頁面調(diào)入內(nèi)存,同時把暫不運行的頁面換到外存上,置換時以頁面為單位。系統(tǒng)須設(shè)置相應(yīng)的硬件支持和軟件:(1)硬件支持:請求分頁的頁表機制、缺頁中斷機構(gòu)和地址變換機構(gòu)。(2)軟件:請求調(diào)頁功能和頁置換功能的軟件。67二、虛擬存儲器的實現(xiàn)方法1、分頁請求系統(tǒng)674.7請求分頁中的頁面置換算法常用的頁面置換算法:最佳置換算法OPT:選擇永遠不再需要的頁面或最長時間以后才需要訪問的頁面予以淘汰。先進先出置換算法FIFO:選擇先進入內(nèi)存的頁面予以淘汰。最近最久未使用置換算法LRU:選擇最近一段時間最長時間沒有被訪問過的頁面予以淘汰。684.7請求分頁中的頁面置換算法常用的頁面置換算法:最佳置換算法(Optimal,OPT)例

假定系統(tǒng)為某進程分配了3個物理塊,進程運行時的頁面走向為1,2,3,4,1,2,5,1,2,3,4,5,開始時3個物理塊均為空,計算采用最佳置換頁面淘汰算法時的缺頁率?注:實際上這種算法無法實現(xiàn),因為頁面訪問的未來順序很難精確預測,但可用該算法評價其它算法的優(yōu)劣。1缺缺缺缺缺缺缺12312121212121212333444442555555(7/12)最佳置換算法:選擇永遠不再需要的頁面或最長時間以后才需要訪問的頁面予以淘汰。69最佳置換算法(Optimal,OPT)例假定系統(tǒng)為某進程分先進先出置換算法(FIFO)例題1、假定系統(tǒng)為某進程分配了3個物理塊,進程運行時的頁面走向為1,2,3,4,1,2,5,1,2,3,4,5,開始時3個物理塊均為空,計算采用先進先出頁面淘汰算法時的缺頁率?(9/12)70先進先出置換算法(FIFO)例題1、假定系統(tǒng)為某進程分配了3最近最久未使用算法LRU例最近最久未使用算法(LRU,LeastRecentlyUsed)例:假定系統(tǒng)為某進程分配了3個物理塊,進程運行時的頁面走向為1,2,3,4,1,2,5,1,2,3,4,5,開始時3個物理塊均為空,計算采用最近最久未使用頁面淘汰算法時的缺頁率?(10/12)最近最久未使用置換算法:選擇最近一段時間最長時間沒有被訪問過的頁面予以淘汰。71最近最久未使用算法LRU例最近最久未使用算法(LRU,Le第五章設(shè)備管理

72第五章設(shè)備管理

725.5.4.SPOOLing技術(shù)SPOOLing(SimultaneousPeripheralOperationsOn-Line,外部設(shè)備聯(lián)機并行操作),也稱假脫機技術(shù)。SPOOLing是指在多道程序的環(huán)境下,利用多道程序中的一道或兩道程序來模擬外圍控制機,從而在聯(lián)機的條件下實現(xiàn)脫機I/O的功能。735.5.4.SPOOLing技術(shù)SPOOLing(Sim5.5.4.SPOOLing技術(shù)設(shè)計思想:可以用常駐內(nèi)存的進程去模擬一臺外圍機,從而用一臺主機就可完成脫機技術(shù)中需用三臺計算機完成的工作。功能:

把獨占設(shè)備改造為邏輯共享設(shè)備。把一臺物理I/O設(shè)備虛擬為多臺邏輯I/O設(shè)備。組成:專門負責I/O的常駐內(nèi)存的進程;輸入井、輸出井;輸入緩沖區(qū)、輸出緩沖區(qū)。745.5.4.SPOOLing技術(shù)設(shè)計思想:可以用常駐內(nèi)存1、磁盤性能磁盤性能簡述數(shù)據(jù)的組織磁盤結(jié)構(gòu):磁道、柱面、扇區(qū)磁盤物理塊的地址:磁頭號、柱面號、扇區(qū)號存儲容量=磁頭(盤面)數(shù)×磁道(柱面)數(shù)×每道扇區(qū)數(shù)×每扇區(qū)字節(jié)數(shù)假定一塊硬盤磁頭數(shù)為4,柱面數(shù)為2048,每個磁道有扇區(qū)2048,每個扇區(qū)記錄1KB(字節(jié)),該硬盤儲存容量為:4×2048×2048×1024/1024/1024/1024=16G4×2048×2048×1024/1000/1000/1000=17.2G(廠家)751、磁盤性能磁盤性能簡述751、磁盤性能訪問時間尋道時間Ts:將磁頭從當前位置移到指定磁道所經(jīng)歷的時間Ts=m×n+s。s為啟動磁臂的時間,n為移動的磁道數(shù),m為常數(shù)。旋轉(zhuǎn)延遲時間Tr:指定扇區(qū)移動到磁頭下面所經(jīng)歷的時間。設(shè)每秒r轉(zhuǎn),則Tr=1/2r(均值)傳輸時間Tt:將扇區(qū)上的數(shù)據(jù)從磁盤讀出或向磁盤寫入數(shù)據(jù)所經(jīng)歷的時間Tt=b/rN。其中b:讀寫字節(jié)數(shù),N:每道上的字節(jié)數(shù)??刂破鲿r間Tc訪問時間Ta:Ta=m×n+s+1/2r+b/rN+Tc761、磁盤性能訪問時間761、磁盤性能例:假設(shè)磁盤空閑(沒有排隊延遲)。平均尋道時間是9ms,傳輸速度是4MB/s,轉(zhuǎn)速是7200rpm,控制器的開銷是1ms。問讀或?qū)懸粋€512字節(jié)的扇區(qū)的平均時間是多少?解:訪問時間=尋道時間+旋轉(zhuǎn)延遲時間+傳輸時間+控制器時間訪問時間=9ms+0.5/7200(rpm)+0.5(k)/4(MB/s)+1ms=9ms+0.5/7200/60/1000+0.5/(4×1024/1000)+1ms≈9+4.2+0.122+1=14.322ms1秒等于1000毫秒771、磁盤性能例:假設(shè)磁盤空閑(沒有排隊延遲)。平均尋道時間磁盤調(diào)度算法磁盤調(diào)度算法早期的磁盤調(diào)度算法先來先服務(wù)FCFS最短尋道時間優(yōu)先SSTF掃描算法掃描(SCAN)/電梯(LOOK)算法循環(huán)掃描(CSCAN)算法本教材不區(qū)分SCAN算法和LOOK算法,我們做題時都按LOOK算法解決(不掃描到頭?。?8磁盤調(diào)度算法磁盤調(diào)度算法78FCFS先來先服務(wù)按進程請求訪問磁盤的先后次序進行調(diào)度磁頭臂來回反復移動,增長了等待時間,對機械結(jié)構(gòu)不利79FCFS先來先服務(wù)按進程請求訪問磁盤的先后次序進行調(diào)度磁最短尋道時間優(yōu)先(SSTF)選擇從當前磁頭位置所需尋道時間最短的請求??赡苁挂恍┥暾堈咴谳^長時間內(nèi)得不得服務(wù)的機會80最短尋道時間優(yōu)先(SSTF)選擇從當前磁頭位置所需尋道時間最假定磁頭向磁道號增加的方向移動。Scan/Look算法81假定磁頭向磁道號增加的方向移動。Scan/Look算法81第六章文件管理

82第六章文件管理

826.2文件邏輯結(jié)構(gòu)對任一文件存在著兩種形式的結(jié)構(gòu):文件的邏輯結(jié)構(gòu)(文件組織)從用戶觀點出發(fā),所觀察到的文件組織形式,是用戶可以直接處理的數(shù)據(jù)及其結(jié)構(gòu),它獨立于物理特性。順序文件、索引文件、索引順序文件文件的物理結(jié)構(gòu)(文件的存儲結(jié)構(gòu))從系統(tǒng)的觀點出發(fā),是指文件在外存上的存儲組織形式,與存儲介質(zhì)的存儲性能有關(guān)。順序文件、鏈接文件、索引文件注:文件的邏輯結(jié)構(gòu)和物理結(jié)構(gòu)都將影響文件的檢索速度。836.2文件邏輯結(jié)構(gòu)對任一文件存在著兩種形式的結(jié)構(gòu):83多級索引分配如果每個盤塊的大小為1KB,每個盤塊號占4個字節(jié),則在一個索引塊中可存放256個盤塊號。在兩級索引時,最多可存放的盤塊號總數(shù)N=256×256=64K個,即所允許的文件最大長度為64MB。如果每個盤塊的大小為4KB,每個盤塊號占4個字節(jié),單級索引時所允許的文件最大長度為如果采用兩級級索引時最大文件長度為1024×4KB=4MB1024×1024×4KB=4GB84多級索引分配如果每個盤塊的大小為1KB,每個盤塊號占4個字混合索引分配直接地址(多個)一次間接地址二次間接地址混合索引分配:地址項既采用了直接地址,又采用了多級索引分配方式。索引結(jié)點(FCB主部)索引塊85混合索引分配直接地址(多個)一次間接地址二次間接地址混合索引練習題例:存放在某個磁盤上的文件系統(tǒng),采用混合索引分配方式,其FCB中共有13個地址項(索引項),第0-9個地址項為直接地址,第10個地址項為一次間接地址,第11個地址項為二次間接地址,第12個地址項為三次間接地址。如果每個盤塊的大小為512字節(jié),盤塊號需要用3個字節(jié)來描述,而每個盤塊最多存放170個盤塊地址。問:(1)該文件系統(tǒng)允許文件的最大長度是多少?(2)將文件的字節(jié)偏移量5000、15000、150000轉(zhuǎn)換為物理塊號和塊內(nèi)偏移量。(3)假設(shè)某個文件的FCB己在內(nèi)存,但其他信息均在外存,為了訪問該文件中某個位置的內(nèi)容,最少需要幾次訪問磁盤,最多需要幾次訪問磁盤?512/3≈17086練習題例:存放在某個磁盤上的文件系統(tǒng),采用混合索引分配方式,練習題解:(1)該文件系統(tǒng)中一個文件的最大長度可達:

10+170+170×170+170×170×170=4942080塊,共4942080×512字節(jié)=2471040KB

≈2.36GB或用如下解法:直接索引項可管理上限:10×0.5KB=5KB;一次間接索引項可管理上限:170×0.5KB=85KB;二次間接索引項可管理上限:170×170×0.5KB=14450KB;三次間接索引項可管理上限:170×170×170×0.5KB=2456500KB;可管理文件上限:5KB+85KB+14450KB+2456500KB。87練習題解:(1)該文件系統(tǒng)中一個文件的最大長度可達:87練習題解:(2)

5000/512得到商為9,余數(shù)為392,即字節(jié)偏移量5000對應(yīng)的邏輯塊號為9,塊內(nèi)偏移量為392。由于9<10,故可直接從該文件的FCB的第9個地址項處得到物理盤塊號,塊內(nèi)偏移量為392。15000/512得到商為29,余數(shù)為152,即字節(jié)偏移量15000對應(yīng)的邏輯塊號為29,塊內(nèi)偏移量為152。由于10<29<10+170,而29-10=19,故可從FCB的第10個地址項,即一次間址項中得到一次間址塊的地址;并從一次間址塊的第19項(即該塊的第57~59這3個字節(jié))中獲得對應(yīng)的物理盤塊號,塊內(nèi)偏移量為152。

盤塊號用3個字節(jié)描述88練習題解:(2)盤塊號用3個字節(jié)描述88練習題150000/512得到商為292,余數(shù)為496,即字節(jié)偏移量150000對應(yīng)的邏輯塊號為292,塊內(nèi)偏移量為496。由于10+170<292<10+170+170×170,而292-(10+170)=112,112/170得到商為0,余數(shù)為112,故可從FCB的第11個地址項,即二次間址項中得到二次間址塊的地址,并從二次間址塊的第0項中獲得一個一次間址塊的地址,再從這一次間址塊的第112項中獲得對應(yīng)的物理盤塊號,塊內(nèi)偏移量為496。89練習題150000/512得到商為292,余數(shù)為496,即字練習題

(3)假設(shè)某個文件的FCB己在內(nèi)存,但其他信息均在外存,為了訪問該文件中某個位置的內(nèi)容,最少需要幾次訪問磁盤,最多需要幾次訪問磁盤?解:由于文件的FCB己在內(nèi)存,為了訪問文件中某個位置的內(nèi)容,最少需要1次訪問磁盤(即可通過直接地址直接讀文件盤塊),最多需要4次訪問磁盤(第一次是讀三次間址塊,第二次是讀二次間址塊,第三次是讀一次間址塊,第四次是讀文件盤塊)。90練習題(3)假設(shè)某個文件的FCB己在內(nèi)存,但其他信息均在文件控制塊(FCB)文件目錄文件目錄是一種數(shù)據(jù)結(jié)構(gòu),用于標識系統(tǒng)中的文件及其物理地址,將文件名映射到外存物理位置,供檢索時使用。目錄項構(gòu)成文件目錄的項目(目錄項就是FCB)文件目錄:文件控制塊的有序集合。目錄文件為了實現(xiàn)對文件目錄的管理,通常將文件目錄以文件的形式保存在外存,這個文件就叫目錄文件。文件目錄和目錄文件是同一事物的兩種稱謂。從用途角度來看稱其為文件目錄,從實現(xiàn)角度來看稱其為目錄文件。91文件控制塊(FCB)文件目錄文件目錄和目錄文件是同一事物的兩索引結(jié)點索引結(jié)點引入文件目錄通常是存放在磁盤上的,當文件很多時,文件目錄可能要占用大量的盤塊。在查找目錄的過程中,先將存放目錄文件的第一個盤塊中的目錄調(diào)入內(nèi)存,然后把用戶所給定的文件名與目錄項中的文件名逐一比較。若未找到指定文件,便再將下一個盤塊中的目錄項調(diào)入內(nèi)存。設(shè)目錄文件所占用的盤塊數(shù)為N,按此方法查找,則查找一個目錄項平均需要調(diào)入盤塊(N+1)/2次。92索引結(jié)點索引結(jié)點引入92解:在引入索引節(jié)點前,256個目錄項的目錄總共需要占用256×64/512=32個盤塊。在目錄中檢索到一個文件平均啟動磁盤次數(shù)為(1+32)/2=16.5。

在引入索引節(jié)點后,每個目錄項中只需存放文件名和索引節(jié)點的編號,因此256個目錄項的目錄總共需要占用256×(8+2)/512=5個盤塊。因此,找到匹配的目錄項平均需要啟動3次磁盤;而得到索引結(jié)點編號后還需啟動磁盤將對應(yīng)文件的索引結(jié)點讀入內(nèi)存,故平均需要啟動磁盤4次。文件控制塊和索引結(jié)點93解:在引入索引節(jié)點前,256個目錄項的目錄總共需要占用2566.5文件存儲空間的管理文件存儲空間的管理可采用連續(xù)分配和離散分配方式。內(nèi)存分配基本不采用連續(xù)分配方式。外存管理中,小文件經(jīng)常采用連續(xù)分配方式,大文件采用離散分配方式。存儲空間的管理方法空閑表法和空閑鏈法位示圖法成組鏈接法文件存儲器空間布局946.5文件存儲空間的管理文件存儲空間的管理可采用連續(xù)分配和6.5.2位示圖法位示圖(二維)利用二進制的一位(bit)來表示磁盤中一個盤塊的使用情況。每個字節(jié)的每一位都對應(yīng)了一個物理塊的狀態(tài)。當該位取1時,表示對應(yīng)的物理塊已分配;取0時表示該物理塊未分配??臻e空間表現(xiàn)為位圖或位向量。特點:占空間少,可放入內(nèi)存,易于訪問。956.5.2位示圖法位示圖(二維)95位示圖法12345678910123456796位示圖法1234練習題1例1:設(shè)某系統(tǒng)的磁盤有500塊,塊號為:0,1,2,3,…,499。(1)若用位示圖法管理這500塊的盤空間,當字長為32位時,此位示圖占了幾個字?(2)第i字的第j位對應(yīng)的塊號是多少?(其中:i=0,1,2,…,j=0,1,2,3,…)解:(1)位示圖法就是在內(nèi)存用一些字建立一張位示圖,用其中的每一位表示一個盤塊的使用情況,通常用“1”表示占用,“0”表示空閑。因此,本問題中位示圖所占的字數(shù)為:500/32=15.625≈16。(2)第i字的第j位對應(yīng)的塊號N=32*i+j。97練習題1例1:設(shè)某系統(tǒng)的磁盤有500塊,塊號為:0,1,2,提問與解答環(huán)節(jié)Questionsandanswers98提問與解答環(huán)節(jié)98添加標題添加標題添加標題添加標題此處結(jié)束語點擊此處添加段落文本.您的內(nèi)容打在這里,或通過復制您的文本后在此框中選擇粘貼并選擇只保留文字99添加標題添加添加添加標題此處結(jié)束語點擊此處添加段落文本.感謝聆聽Theusercandemonstrateonaprojectororcomputer,orprintthepresentationandmakeitintoafilm講師:XXXX日期:20XX.X月100感謝聆聽講師:XXXX日期:20XX.X月100計算機操作系統(tǒng)復習

2022年11月25日101計算機操作系統(tǒng)復習

2022年11月22日1標題添加點擊此處輸入相關(guān)文本內(nèi)容點擊此處輸入相關(guān)文本內(nèi)容前言點擊此處輸入相關(guān)文本內(nèi)容標題添加點擊此處輸入相關(guān)文本內(nèi)容102標題添加點擊此處輸入相點擊此處輸入前言點擊此處輸入標題添加點課程主要內(nèi)容教材內(nèi)容操作系統(tǒng)引論(第1章)進程管理(第2章)處理機調(diào)度與死鎖(第3章)存儲管理(第4章)設(shè)備管理(第5章)文件管理(第6章)UNIX系統(tǒng)內(nèi)核結(jié)構(gòu)(第10章)103課程主要內(nèi)容教材內(nèi)容3計算題類型總結(jié)利用信號量實現(xiàn)進程同步處理機調(diào)度算法(周轉(zhuǎn)時間)銀行家算法分區(qū)存儲管理算法邏輯地址物理地址變換請求分頁中的頁面置換算法磁盤訪問時間磁盤調(diào)度算法(平均移道數(shù))混合索引分配文件控制塊和索引結(jié)點位示圖104計算題類型總結(jié)利用信號量實現(xiàn)進程同步4第一章操作系統(tǒng)引論

105第一章操作系統(tǒng)引論

51.3操作系統(tǒng)的基本特征并發(fā)性(Concurrence)共享性(Sharing)虛擬性(Virtual)異步性(Asynchronism)基本特征:最重要特性,其它三種特性以此為前提。1061.3操作系統(tǒng)的基本特征并發(fā)性(Concurrence)操作系統(tǒng)的形成單道批處理系統(tǒng)多道批處理系統(tǒng)操作系統(tǒng)的形成在多道程序系統(tǒng)中增設(shè)一組軟件以有效加以解決,同時增設(shè)方便用戶使用計算機的軟件,這樣便形成了操作系統(tǒng)。操作系統(tǒng):是一組控制和管理計算機硬件和軟件資源,合理地對各類作業(yè)進行調(diào)度,以及方便用戶使用的程序集合。107操作系統(tǒng)的形成單道批處理系統(tǒng)操作系統(tǒng):是一組控制和管理計算機操作系統(tǒng)的結(jié)構(gòu)設(shè)計傳統(tǒng)的操作系統(tǒng)結(jié)構(gòu)無結(jié)構(gòu)操作系統(tǒng)模塊化OS結(jié)構(gòu)分層式OS結(jié)構(gòu)現(xiàn)代操作系統(tǒng)結(jié)構(gòu)微內(nèi)核的OS結(jié)構(gòu):將客戶/服務(wù)器技術(shù)、面向?qū)ο蠹夹g(shù)用于OS中所形成的OS結(jié)構(gòu)。108操作系統(tǒng)的結(jié)構(gòu)設(shè)計傳統(tǒng)的操作系統(tǒng)結(jié)構(gòu)8第二章進程管理

109第二章進程管理

92、進程process的基本特征

(1)結(jié)構(gòu)特征從結(jié)構(gòu)上看,每個進程(進程實體)都是由程序段、數(shù)據(jù)段及進程控制塊(PCB)組成。

(2)動態(tài)性

進程的實質(zhì)是程序在處理機上的一次執(zhí)行過程,因此是動態(tài)性的。所以動態(tài)性是進程的最基本的特征。同時動態(tài)性還表現(xiàn)在進程則是有生命期的,它因創(chuàng)建而產(chǎn)生,因調(diào)度而執(zhí)行,因得不到資源而暫停,因撤消而消亡。進程的定義、特征1102、進程process的基本特征進程的定義、特征10

進程在運行期間并非固定處于某個狀態(tài),而是不斷從一個狀態(tài)轉(zhuǎn)換到另一個狀態(tài)。二、進程狀態(tài)2、進程狀態(tài)轉(zhuǎn)換111進程在運行期間并非固定處于某個狀態(tài),而是不斷從一個狀態(tài)轉(zhuǎn)換具有掛起狀態(tài)的進程狀態(tài)活動就緒執(zhí)行掛起調(diào)度時間片完活動阻塞事件發(fā)生等待事件靜止就緒靜止阻塞激活掛起事件發(fā)生激活掛起112具有掛起狀態(tài)的進程狀態(tài)活動就緒執(zhí)行掛起調(diào)度時間片完活動阻塞事線程的基本概念進程是資源分配的單位,而線程是處理機調(diào)度的單位。一個進程可以創(chuàng)建一個或多個線程。多個線程會爭奪CPU,在不同的狀態(tài)之間進行轉(zhuǎn)換。線程也是一個動態(tài)的概念,也有一個從創(chuàng)建到消亡的生命過程,具多種狀態(tài)。同一進程中的所有線程都具有相同的地址空間(進程的地址空間)。113線程的基本概念進程是資源分配的單位,而線程是處理機調(diào)度的單位線程的實現(xiàn)方式

線程的實現(xiàn)方式內(nèi)核支持線程的實現(xiàn)直接利用系統(tǒng)調(diào)用進行線程控制。用戶級線程的實現(xiàn)不能直接利用系統(tǒng)調(diào)用。為了取得內(nèi)核的服務(wù)(獲得系統(tǒng)資源),需要借助中間系統(tǒng)(運行時系統(tǒng)、輕型進程)。114線程的實現(xiàn)方式線程的實現(xiàn)方式14同步機制應(yīng)遵循的規(guī)則空閑讓進:當無進程處于臨界區(qū)時,表明臨界資源處于空閑狀態(tài),應(yīng)允許一個請求進入臨界區(qū)的進程立即進入自己的臨界區(qū),以有效地利用臨界資源。忙則等待:當已有進程進入臨界區(qū)時,表明臨界資源正在被訪問,因而其他試圖進入臨界區(qū)的進程必須等待,以保證對臨界資源的互斥訪問。有限等待:對要求訪問臨界資源的進程,應(yīng)保證在有限時間內(nèi)能進入自己的臨界區(qū),以免陷入死等狀態(tài)。讓權(quán)等待:當進程不能進入自己的臨界區(qū)時,應(yīng)立即釋放處理機,以免進程陷入忙等。115同步機制應(yīng)遵循的規(guī)則空閑讓進:當無進程處于臨界區(qū)時,表明臨界信號量機制信號量機制信號量用于表示資源數(shù)目或請求使用某一資源的進程個數(shù)的整型量。整型信號量記錄型信號量信號量集(AND信號量集、一般信號量集)116信號量機制信號量機制16利用信號量實現(xiàn)進程同步例:進程A與進程B共享同一文件file,設(shè)此文件要求互斥使用,則可將file作為臨界資源,有關(guān)file的使用程序段分別為臨界區(qū)CSA和CSB。

semaphoremutex=1;PA:{ L1:P(mutex); CSA;

V(mutex);

remainderofprocessA; GOTOL1;}PB:{ L2:P(mutex); CSB;

V(mutex); remainderofprocessB;GOTOL2;}

117利用信號量實現(xiàn)進程同步例:進程A與進程B共享同一文件fileS1S3S2S4S5S6S7S8例:利用信號量來描述前趨圖關(guān)系利用信號量實現(xiàn)進程同步118S1S3S2S4S5S6S7S8例:利用信號量來描述前趨圖關(guān)

具有8個結(jié)點的前趨圖。圖中的前趨圖中共有10條有向邊,可設(shè)10個信號量,初值均為0;有8個結(jié)點,可設(shè)計成8個并發(fā)進程,具體描述如下:S1S3S2S4S5S6S7S8agefbcdhij利用信號量實現(xiàn)進程同步119具有8個結(jié)點的前趨圖。圖中的前趨圖中共有10條有向邊Structsmaphorea,b,c,d,e,f,g,h,i,j=0,0,0,0,0,0,0,0,0,0cobegin{S1;V(a);V(b);V(c);}{P(a);S2;V(d);}{P(b);S3;V(e);V(f);}{P(c);S4;V(g);}{P(d);P(e);S5;V(h);}{P(f);P(g);S6;V(i)}{P(h);P(i);S7;V(j);}{P(j);S8;}coendS1S3S2S4S5S6S7S8agefbcdhij利用信號量實現(xiàn)進程同步120Structsmaphorea,b,c,d,e,f,g,2.4經(jīng)典進程的同步問題

在多道程序環(huán)境下,進程同步問題十分重要,出現(xiàn)一系列經(jīng)典的進程同步問題,其中有代表性有:生產(chǎn)者—消費者問題哲學家進餐問題讀者—寫者問題其他同步問題1212.4經(jīng)典進程的同步問題在多道程序“哲學家進餐”問題問題描述:有五個哲學家,他們的生活方式是交替地進行思考和進餐。他們共用一張圓桌,分別坐在五張椅子上。在圓桌上有五個碗和五支筷子,平時一個哲學家進行思考,饑餓時便試圖取用其左、右最靠近他的筷子,只有在他拿到兩支筷子時才能進餐。進餐畢,放下筷子又繼續(xù)思考。解決死鎖問題的例子122“哲學家進餐”問題問題描述:解決死鎖問題的例子22哲學家進餐問題的改進解法方法一:至多只允許四位哲學家同時去拿左筷子,最終能保證至少有一位哲學家能進餐,并在用完后釋放兩只筷子供他人使用。方法二:僅當哲學家的左右手筷子都拿起時才允許進餐。方法三:規(guī)定奇數(shù)號哲學家先拿左筷子再拿右筷子,而偶數(shù)號哲學家相反。123哲學家進餐問題的改進解法方法一:至多只允許四位哲學家同時去拿哲學家進餐問題的改進解法方法一:至多只允許四位哲學家同時去拿左筷子,最終能保證至少有一位哲學家能進餐,并在用完后釋放兩只筷子供他人使用。設(shè)置一個初值為4的信號量r,只允許4個哲學家同時去拿左筷子,這樣就能保證至少有一個哲學家可以就餐,不會出現(xiàn)餓死和死鎖的現(xiàn)象。原理:至多只允許四個哲學家同時進餐,以保證至少有一個哲學家能夠進餐,最終總會釋放出他所使用過的兩支筷子,從而可使更多的哲學家進餐。124哲學家進餐問題的改進解法方法一:至多只允許四位哲學家同時去拿哲學家進餐問題的改進解法semaphorechopstick[5]={1,1,1,1,1};semaphorer=4;voidphilosopher(inti){while(true){think();wait(r);//請求進餐wait(chopstick[i]);//請求左手邊的筷子wait(chopstick[(i+1)mod5]);//請求右手邊的筷子eat();signal(chopstick[(i+1)mod5]);//釋放右手邊的筷子signal(chopstick[i]);//釋放左手邊的筷子signal(r);//釋放信號量rthink();}}125哲學家進餐問題的改進解法semaphorechopstic哲學家進餐問題的改進解法方法二:僅當哲學家的左右手筷子都拿起時才允許進餐。解法1:利用AND型信號量機制實現(xiàn)。原理:多個臨界資源,要么全部分配,要么一個都不分配,因此不會出現(xiàn)死鎖的情形。126哲學家進餐問題的改進解法方法二:僅當哲學家的左右手筷子都拿起哲學家進餐問題的改進解法semaphorechopstick[5]={1,1,1,1,1};voidphilosopher(inti){while(true){think();Swait(chopstick[i];chopstick[(i+1)mod5]);eat();Ssignal(chopstick[(i+1)mod5];chopstick[i]);think();}}127哲學家進餐問題的改進解法semaphorechopstic哲學家進餐問題的改進解法方法二:僅當哲學家的左右手筷子都拿起時才允許進餐。解法2:利用信號量的保護機制實現(xiàn)。原理:通過互斥信號量mutex對eat()之前取左側(cè)和右側(cè)筷子的操作進行保護,可以防止死鎖的出現(xiàn)。128哲學家進餐問題的改進解法方法二:僅當哲學家的左右手筷子都拿起哲學家進餐問題的改進解法semaphoremutex=1;semaphorechopstick[5]={1,1,1,1,1};voidphilosopher(inti){while(true){think();wait(mutex);wait(chopstick[i]);wait(chopstick[(i+1)mod5]);signal(mutex);eat();signal(chopstick[(i+1)mod5]);signal(chopstick[i]);think();

}}129哲學家進餐問題的改進解法semaphoremutex=哲學家進餐問題的改進解法方法三:規(guī)定奇數(shù)號哲學家先拿左筷子再拿右筷子,而偶數(shù)號哲學家相反。原理:按照下圖,將是2,3號哲學家競爭3號筷子,4,5號哲學家競爭5號筷子。1號哲學家不需要競爭。最后總會有一個哲學家能獲得兩支筷子而進餐。先申請的哲學家會較先可以吃飯并釋放筷子,因此不會出現(xiàn)餓死的哲學家。1221334455130哲學家進餐問題的改進解法方法三:規(guī)定奇數(shù)號哲學家先拿左筷子再哲學家進餐問題的改進解法semaphorechopstick[5]={1,1,1,1,1};voidphilosopher(inti){while(true){if(imod2==0)//偶數(shù)哲學家,先右后左。{wait(chopstick[(i+1)mod5]);wait(chopstick[i]);eat();signal(chops

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論