操作系統(tǒng)第五版費祥林-課后習題答案參考_第1頁
操作系統(tǒng)第五版費祥林-課后習題答案參考_第2頁
操作系統(tǒng)第五版費祥林-課后習題答案參考_第3頁
操作系統(tǒng)第五版費祥林-課后習題答案參考_第4頁
操作系統(tǒng)第五版費祥林-課后習題答案參考_第5頁
已閱讀5頁,還剩107頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、第一章 操作系統(tǒng)概論1、有一臺計算機,具有IMB 內存,操作系統(tǒng)占用200KB ,每個用戶進程各占200KB 。如果用戶進程等待I/O 的時間為80 % ,若增加1MB 內存,則CPU 的利用率提高多少?答:設每個進程等待I/O 的百分比為P ,則n 個進程同時等待刀O 的概率是Pn ,當n 個進程同時等待I/O 期間CPU 是空閑的,故CPU 的利用率為1-Pn。由題意可知,除去操作系統(tǒng),內存還能容納4 個用戶進程,由于每個用戶進程等待I/O的時間為80 % , 故:CPU利用率l-(80%)4 = 0.59 若再增加1MB 內存,系統(tǒng)中可同時運行9 個用戶進程,此時:cPu 利用率l-(1

2、-80%)9 = 0.87 故增加IMB 內存使CPU 的利用率提高了47 % : 87 /59 =147 % 147 -100 % = 47 % 2 一個計算機系統(tǒng),有一臺輸入機和一臺打印機,現(xiàn)有兩道程序投入運行,且程序A 先開始做,程序B 后開始運行。程序A 的運行軌跡為:計算50ms 、打印100ms 、再計算50ms 、打印100ms ,結束。程序B 的運行軌跡為:計算50ms 、輸入80ms 、再計算100ms ,結束。試說明(1 )兩道程序運行時,CPU有無空閑等待?若有,在哪段時間內等待?為什么會等待?( 2 )程序A 、B 有無等待CPU 的情況?若有,指出發(fā)生等待的時刻。答:

3、畫出兩道程序并發(fā)執(zhí)行圖如下:(1)兩道程序運行期間,CPU存在空閑等待,時間為100 至150ms 之間(見圖中有色部分)(2)程序A 無等待現(xiàn)象,但程序B 有等待。程序B 有等待時間段為180rns 至200ms 間(見圖中有色部分)3 設有三道程序,按A 、B 、C優(yōu)先次序運行,其內部計算和UO操作時間由圖給出。 試畫出按多道運行的時間關系圖(忽略調度執(zhí)行時間)。完成三道程序共花多少時間?比單道運行節(jié)省了多少時間?若處理器調度程序每次進行程序轉換化時lms , 試畫出各程序狀態(tài)轉換的時間關系圖。答:1 )忽略調度執(zhí)行時間,多道運行方式(搶占式):?搶占式共用去190ms ,單道完成需要26

4、0ms ,節(jié)省70ms 。忽略調度執(zhí)行時間,多道運行方式(非搶占式): 非搶占式共用去180ms ,單道完成需要260ms ,節(jié)省80ms 。2 )調度執(zhí)行時間1ms , 多道運行方式(搶占式): 調度執(zhí)行時間ITns ,多道運行方式(非搶占式): 4在單CPU 和兩臺 I/O( I1 , 12 )設備的多道程序設計環(huán)境下,同時投入三個作業(yè)運行。它們的執(zhí)行軌跡如下:Jobl : I2 ( 30ms )、CPU ( 10ms )、I1 ( 30ms )、CPU ( 10ms )、I2 ( 20ms ) Job2 : I1 ( 20ms )、CPU ( 20ms )、I2 ( 40 ms ) JO

5、b3 : CPU ( 30ms )、I1 ( 20ms )、CPU ( 10ms )、I1 ( 10ms ) 如果CPU 、I1 和I2 都能并行工作,優(yōu)先級從高到低為Jobl 、Job2 和Job3 ,優(yōu)先級高的作業(yè)可以搶占優(yōu)先級低的作業(yè)的CPU ,但不搶占I1和I2 。試求:( l )每個作業(yè)從投入到完成分別所需的時間。(2 )從投入到完成CPU 的利用率。(3 )I2設備利用率。答:畫出三個作業(yè)并行工作圖如下(圖中著色部分為作業(yè)等待時間): ,( 1 ) Job1 從投入到運行完成需110ms , Job2 從投入到運行完成需90ms , Job3 從投入到運行完成需110ms. CPU

6、 空閑時間段為:60ms 至70ms , 80ms 至90ms , 100ms 至110ms 。所以CPU 利用率為(110-30)/10 = 72.7 。設備I1 空閑時間段為:20ms 至40ms , 90ms 至100ms,故I1的利用率為 (110-30)/l10 = 72 . 7 。 設備I2 空閑時間段為:30ms 至50ms,故I2的利用率為(110-20) / 110 = 81.8 。 5 在單CPU 和兩臺I/O( I1 , 12 )設備的多道程序設計環(huán)境下,同時投入三個作業(yè)運行。它們的執(zhí)行軌跡如下:Jobl : I2 ( 30ms )、CPU ( 10rns )、I1 (

7、30ms )、CPU ( 10ms ) Job2 : I1 ( 20ms )、CPU ( 20ms )、I2 ( 40ms ) Job3 : CPU ( 30ms )、I1 ( 20ms ) 如果CPU 、I1和I2 都能并行工作,優(yōu)先級從高到低為Job1 、Job2和Job3 ,優(yōu)先級高的作業(yè)可以搶占優(yōu)先級低的作業(yè)的CPU 。 試求:( l )每個作業(yè)從投入到完成分別所需的時間 ( 2 )每個作業(yè)投入到完成CPU 的利用率。 (3 )I/0設備利用率。 答:畫出三個作業(yè)并行工作圖如下(圖中著色部分為作業(yè)等待時間): ( 1 ) Job1從投入到運行完成需80ms , Job2 從投入到運行完

8、成需90ms , Job3 從投入到運行完成需90ms 。( 2 ) CPU 空閑時間段為:60ms 至70ms , 80ms 至90ms 。所以CPU利用率為( 90-20 ) / 90 = 77.78 。( 3 )設備I1 空閑時間段為:20ms 至40ms ,故I1 的利用率為(90-20 ) / 90 = 77 . 78 。設備I2 空閑時間段為:30ms 至50ms ,故I2 的利用率為(90-20 ) / 90=77.78 。6 若內存中有3 道程序A 、B 、C ,它們按A 、B 、C 優(yōu)先次序運行。各程序的計算軌跡為:A :計算(20 )、I/O( 30 )、計算(10 ) B

9、 :計算(40 )、I/O( 20 )、計算(10 ) c :計算(10 )、I/O ( 30 )、計算(20 ) 如果三道程序都使用相同設備進行I/O(即程序用串行方式使用設備,調度開銷忽略不計)。試分別畫出單道和多道運行的時間關系圖。兩種情況下,CPU 的平均利用率各為多少?答:分別畫出單道和多道運行的時間圖( 1 )單道運行時間關系圖 單道總運行時間為190ms 。CPU 利用率為(190-80 )/190 = 57.9 % 單道運行時間關系圖 多道總運行時間為140ms 。CPU 利用率為(140-30 ) / 140 = 78.6 % 7 若內存中有3 道程序A 、B 、C ,優(yōu)先級

10、從高到低為A 、B 和C ,它們單獨運行時的CPU 和I/O 占用時間為:如果三道程序同時并發(fā)執(zhí)行,調度開銷忽略不計,但優(yōu)先級高的程序可中斷優(yōu)先級低的程序,優(yōu)先級與I/O 設備無關。試畫出多道運行的時間關系圖,并問最早與最遲結束的程序是哪個?每道程序執(zhí)行到結束分別用了多少時間?計算三個程序全部運算結束時的CPU 利用率?答:畫出三個作業(yè)并發(fā)執(zhí)行的時間圖: ( l )最早結束的程序為B ,最后結束的程序為C 。 ( 2 )程序A 為250ms 。程序B 為220ms 。程序C 為310ms 。 ( 3 ) CPU 利用率為(310 -120 ) / 310 = 61.3 % 有兩個程序,A 程序

11、按順序使用:( CPU)10 秒、(設備甲)5 秒、(CPU)5 秒、(設備乙)10 秒、(CPU)10 秒。B程序按順序使用:(設備甲)10 秒、(CPU)10 秒、(設備乙)5 秒、( CPU)5 秒、(設備乙)10 秒。在順序環(huán)境下先執(zhí)行A ,再執(zhí)行B ,求出總的CPU 利用率為多少?答:程序A 執(zhí)行了40 秒,其中CPU 用了25 秒。程序B 執(zhí)行了40 秒,其中CPU 用了15 秒。兩個程序共用了80 秒,CPU 化 40 秒。故CPU 利用率為40/80 =50 。9、在某計算機系統(tǒng)中,時鐘中斷處理程序每次執(zhí)行的時間為2ms (包括進程切換開銷)。若時鐘中斷頻率為60HZ ,試問C

12、PU用于時鐘中斷處理的時間比率為多少?答:因時鐘中斷頻率為60HZ ,所以,時鐘周期為:l / 60s = 50/3ms 。在每個時鐘周期中,CPU 花2ms 執(zhí)行中斷任務。所以,CPU 用于時鐘中斷處理的時間比率為:2(50/3)=6/50 = 12。第二章 處理器管理1.下列指令中哪些只能在核心態(tài)運行?(l)讀時鐘日期;(2)訪管指令;(3)設時鐘日期;(4)加載PSW; (5)置特殊寄存器:(6)改變存儲器映象圖;(7)啟動I/O指令。答:( 3 ) , ( 4 ) , ( 5 ) , ( 6 ) , ( 7 ) .2 假設有一種低級調度算法是讓“最近使用處理器較少的進程”運行,試解釋這

13、種算法對“I/O 繁重”型作業(yè)有利,但并不是永遠不受理“處理器繁重”型作業(yè)。答:因為I/O繁忙型作業(yè)忙于I/O,所以它CPU 用得少,按調度策略能優(yōu)先執(zhí)行。同樣原因一個進程等待CPU 足夠久時,由于它是“最近使用處理器較少的進程”,就能被優(yōu)先調度,故不會饑餓。3 并發(fā)進程之間有什么樣的相互制約關系?下列日常生活中的活動是屬哪種制約關系:(1)踢足球,(2)吃自助餐,(3)圖書館借書,(4)電視機生產流水線工序。答:并發(fā)進程之間的基本相互制約關系有互斥和同步兩種。其中(1)、(3)為互斥問題(2)、(4)為同步問題。4 在按動態(tài)優(yōu)先數(shù)調度進程的系統(tǒng)中,每個進程的優(yōu)先數(shù)需定時重新計算。在處理器不斷

14、地在進程之間交替的情況下,重新計算進程優(yōu)先數(shù)的時間從何而來?答:許多操作系統(tǒng)重新計算進程的優(yōu)先數(shù)在時鐘中斷處理例程中進行,由于中斷是隨機碰到哪個進程,就插入哪個進程中運行處理程序,并把處理時間記在這個進程的賬上。5 若后備作業(yè)隊列中等待運行的同時有三個作業(yè)J1 、J2、J3 ,已知它們各自的運行時間為a 、b 、c,且滿足a < b c,試證明采用短作業(yè)優(yōu)先算法調度能獲得最小平均作業(yè)周轉時間。答:采用短作業(yè)優(yōu)先算法調度時,三個作業(yè)的總周轉時間為:Tl = = a + ( a +b ) + ( a + b + c ) = 3a + 2b + c 若不按短作業(yè)優(yōu)先算法調度,不失一般性,設調度

15、次序為:J2 、J1 、J3 。則三個作業(yè)的總周轉時間為:T2=b(ba ) (ba + c ) = 3b + 2a + c 令- 式得到:T2 - Tl = b- a> 0 可見,采用短作業(yè)優(yōu)先算法調度才能獲得最小平均作業(yè)周轉時間。 6、若有一組作業(yè)J1 , ,Jn ,其執(zhí)行時間依次為S1 , , Sn 。如果這些作業(yè)同時到試找出一種作業(yè)調度算法到達系統(tǒng),并在一臺單CPU 處理器上按單道方式執(zhí)行。使得平均作業(yè)周轉時間最短。答:首先,對n 個作業(yè)按執(zhí)行時間從小到大重新進行排序,則對n 個作業(yè):J1 ' , ,Jn , 創(chuàng)門的運行時間滿足:S1S2 S (n-l ) Sn 。那么有

16、:由于任何調度方式下,S1' + S2' + S3'Sn為一個確定的數(shù),而當S1 S2 S( n - 1 ) Sn 時才有:0*S1+1*S2+2*S3+(n-1)Sn的值最大,也就是說,此時T 值最小。所以,按短作業(yè)優(yōu)先調度算法調度時,使得平均作業(yè)周轉時間最短。7、 假定執(zhí)行表中所列作業(yè),作業(yè)號即為到達順序,依次在時刻0 按次序1 、2 、3 、4 、5 進入單處理器系統(tǒng)。(1)分別用先來先服務調度算法、時間片輪轉算法、短作業(yè)優(yōu)先算法及非強占優(yōu)先權調度算法算出各作業(yè)的執(zhí)行先后次序(注意優(yōu)先權高的數(shù)值?。? (2)計算每種情況下作業(yè)的平均周轉時間和平均帶權周轉時間。 (

17、 1 )采用FCFS 算法調度作業(yè),運作情況: ( 2 )采用雙算法調度作業(yè),若令時間片長l ,各作業(yè)執(zhí)行情況為:1 、2 、3 、4 、5 、l 、3 、5 、1 、5 、1 、5 、1 、5 、1 、l 、l 、1 、1 。 ( 3 )采用SJF 算法調度作業(yè),運作情況: ( 4 )采用非剝奪優(yōu)先權算法調度作業(yè),運作情況:8 對某系統(tǒng)進行監(jiān)測后表明平均每個進程在I/O 阻塞之前的運行時間為T 。一次進程切換的系統(tǒng)開銷時間為S 。若采用時間片長度為Q 的時間片輪轉法,對下列各種情況算出CPU 利用率。9 有5 個待運行的作業(yè),各自預計運行時間分別是:9 、6 、3 、5 和x ,采用哪種運行

18、次序使得平均響應時間最短?答:按照最短作業(yè)優(yōu)先的算法可以使平均響應時間最短。x 取值不定,按照以下情況討論:10.有5 個批處理作業(yè)A 到E 均己到達計算中心,其運行時間分別2 、4 、6 、8 和10 分鐘:各自的優(yōu)先級分跳狠掀完為、飛、飛、氏積5 、這里5 為最高級。對于1) 時間片輪轉算法、2)優(yōu)先數(shù)法、3)短作業(yè)優(yōu)先算法、4)先來先服務調度算法(按到達次序C 、D 、B 、E 、A) ,在忽略進程切換時間的前提下,計算出平均作業(yè)周轉時間。(對l)每個作業(yè)獲得相同的2 分鐘長的時間片;對2)到4)采用單道運行,直到結束。)答:( l ) FCFS 調度算法 ( 2 )優(yōu)先級調度算法( 3

19、 )時間片輪轉法按次序ABCDEBCDECDEDEE 輪轉執(zhí)行。( 4 ) SJF調度算法 11、 有5 個批處理作業(yè)A 到E 均已到達計算中心,其運行時間分別10 、6 、2 、4 和8 分鐘;各自的優(yōu)先級分別被規(guī)定為3 、5 、2 、1 和4 ,這里5 為最高級。若不考慮系統(tǒng)切換開銷,計算出平均作業(yè)周轉時間。(1) FCFs (按A 、B 、C 、D 、E ) ; (2) 優(yōu)先級調度算法,(3)時間片輪轉法(每個作業(yè)獲得相同的2 分鐘長的時間片)。答:( 1 ) FCFS 調度算法 ( 2 )優(yōu)先級調度算法( 3 )時間片輪轉法 按次序ABCDEABDEABEAEA 輪轉執(zhí)行。 作業(yè) 執(zhí)行

20、時間 等待時間 周轉時間 帶權周轉時間      ABCDE 10 6 2 48 20l64 l220 302261628 33 .6634 3. 5 作業(yè)平均周轉時間作業(yè)平均帶權周轉時間 T = ( 30 + 22 + 6 + 16 + 28 ) / 5 = 20.4W = ( 3 + 3.66 + 3 +4 + 3.5 ) / 5 = 3.43     12 (l)假定一個處理器正在執(zhí)行兩道作業(yè),一道以計算為主,另一道以輸入輸出為主,你將怎樣賦予它們占有處理器的優(yōu)先級?為什么?(2)假定一個處理器正在

21、執(zhí)行三道作業(yè),一道以計算為主,第二道以輸入輸出為主,第三道為計算與輸入輸出均勻。應該如何賦予它們占有處理器的優(yōu)先級使得系統(tǒng)效率較高?答:處理器調度算法會考慮以下因素:作業(yè)響應時間要求;讓CPU 盡量和外圍設備并行工作;限制一個計算進程長時間霸占處理器。因而,( 1 ) FO 為主作業(yè)優(yōu)先級高。(2 ) 輸入輸出為主作業(yè)優(yōu)先級最高,輸入輸出均勻的作業(yè)其次,而計算為主作業(yè)的優(yōu)先級最低。 13 請你設計一種先進的計算機體系結構,它使用硬件而不是中斷來完成進程切換,則CPU 需要哪些信息?請描述用硬件完成進程切換的工作過程。 答:該計算機有一個專用硬件寄存器,它始終存放指向當前運行進程的PCB 的指針

22、。當系統(tǒng)中發(fā)生了一個事件,如FO 結束事件,CPU 便可把運行進程的上下文保存到專用硬件寄存器指針指向的PCB 中保護起來,然后,CPU 轉向中斷向量表,找到設備中斷處理程序入口,讓專用硬件寄存器指針指向(設備)中斷服務例程,于是,便可啟動中斷服務例程工作。 14 設計一條機器指令和一種與信號量機制不同的算法,使得并發(fā)進程對共享變量的使用不會出現(xiàn)與時間有關的錯誤。解:( l )設計機器指令。設計一條如下的”測試、比較和交換”三地址指令,提供了一種硬件互斥解決方案: TC&S R1R3B2D2該指令的功能如下:l ) C 為一個共享變量,由地址2 、即變址(B2 ) + D2 給出, (

23、2 )(Rl )與(C )比較, (3 )如果(Rl ) = ( C )則(R3)C ,并置條件碼為"00" , 如果(R1 )(c )則(C )Rl ,并置條件碼為"01 " . ( 2 )編寫進程訪問共享變量的程序。對每個訪問共享變量C 的進程,編寫訪問共享變量的程序段為: 陸界區(qū)程序 說明 ( C )Rl ;loop2 : ( R1 ) R3 ; Add /decrease R3 ;TC & S ;R( condition = 01 ) loop2 ; 共享變量C 的值保護到RI 中。 Rl 的值傳送到R3 中,進程修改共享變量時,先對R3

24、 操作(不是直接操作C )。 R3 加1 減1 ,進程歸還申請由共享變量C 代表的共享資源(假定每次一個)。 執(zhí)行”測試、比較和交換”指令。 條件碼01 ,轉向循環(huán)loop2 ;否則離開臨界區(qū)。    ( 3 )程序執(zhí)行說明。此解與互斥使用共享變量的思路絕然不同,并發(fā)運行的進程可不互斥地訪問它們的共享變量。此方案認為造成共享變量C 值錯誤的原因在于:一個進程(Pl )在改變C 值的過程中,另一個進程伊2 )插進來也改變了C 的值,而本進程(Pl)卻不知道,造成了c 值結果不正確。如果有辦法使本進程口1 )能知道C 值是否改變,改變的話在繼承改變了的C 值的基礎上,

25、再作自己的改變操作,則就不會導致共享變量C 值的錯誤。為此,本解決方案中,當一個進程l)準備改變C 值時,先把C 的值保護在Rl 中,然后,通過R3 來改變共享變量C 的值。當要把新的值(即R3 內的值)送C之前,先要判斷一下在本進程(P1 )工作期間是否有別的進程口2 )插進來也改變了C 的值(并發(fā)進程P1 、P2 的執(zhí)行完全會造成這種情況),方法是:將扭1 )中被保護的C 的原來值,與C 的當前值比較,若相等,說明C 值未被改變過,則將本進程(Pl )修改過的新值送C (即(R3 ) 一C ) ;若不相等,說明C 值在工作期間被改變過,則應該繼承C 的新值(即(C )一Rl )并且返回到l

26、oop2 處重新對C值計數(shù),以此保證C值的最終結果的正確性。這里提及”進程工作期間”指的是一個進程從開始至結束對共享變量C 值的操作的這段時間,也就是執(zhí)行進程,' I 晦界區(qū)”這段程序的時間。此外,在進程進入臨界區(qū)之前,應等待直到C 為非。(即有資源可用)為止。( 4 )舉例。假定系統(tǒng)中有靜態(tài)分配資源磁帶機共3 臺,被N 個進程共享,由共享變量C 來代表可用磁帶機臺數(shù),其初值為3 ?,F(xiàn)有并發(fā)進程P1 和P2 均申請使用磁帶機,執(zhí)行臨界區(qū)程序。進程Pl 執(zhí)行臨界區(qū)程序( C )R1 ;因(C)=3 ,故(R1) = 3 。 loop2: ( Rl )R3 因(R1 ) = 3 ,故(R3

27、 )當前也3 。 decrease R3 :申請使用磁帶機,做減1 操作,故(R3 )=2. TC & S 執(zhí)行”測試、比較和交換,, TC & S 指令。如果R1=(C )則(R3 )C,即(C)=2 ,并置條件碼為”00" , 跳出臨界區(qū)程序,去使用磁帶機。如果(Rl ) (C) ,例如,( C )=2 ,說明進程P2 搶先申請了磁帶機,所以,C 與保護在R1 中的值不一樣了(C 的值必 小于Rl 的值),應以C 的當前值為準,執(zhí)行(C ) Rl ( R1 此時變?yōu)? ) ,并置條件碼為”01 " ,轉向foopZ 。于是伍1 ) = 2 , 跟著(R3

28、 卜2 。接著卿)減1 后應l 了。再執(zhí)行TC & S 時,由于伍1 卜(C ) = 2 ,會使C 變?yōu)? 。 r ( conditio 二01 ) loop2 ; 巧單道批處理系統(tǒng)中,下列三個作業(yè)采用先來先服務調度算法和最高響應比優(yōu)先算法進行調度,哪一種算法性能較好?請完成下表: 作業(yè) 提交時間 運行時間 開始時間 完成時間 周轉時間 帶權周轉時間 12310 : 0010 : 1010 : 252 : 001 : 000 : 25    平均作業(yè)周轉時間=平均作業(yè)帶權周轉時間W =   答: 可見HRRF 比FI

29、FO 要好 16 若有如表所示四個作業(yè)進入系統(tǒng),分別計算在FCFS 、S 開和HRR 衛(wèi)算法下的平均周轉時間與帶權平均周轉時間。(時間以十進制表示) 答: 17 Kleinrock 提出一種動態(tài)優(yōu)先權算法:進程在就緒隊列等待時,其優(yōu)先權以速率a變化;當進程在處理器上運行,時其優(yōu)先權以速率p 變化。給參數(shù)a,b 賦以不同值可得到不同算法。(l )若abc是什么算法?( 2 )若abc是什么算法 答:( l )是先進先出算法。因為在就緒隊列中的進程比在CPU 上運行的進程的優(yōu)先數(shù)提高得快,故進程切換時,先進入就緒隊列的進程優(yōu)先權就越高。( 2 )是后進先出算法。因為在就緒隊列中的進程比在CPU 上

30、運行的進程的優(yōu)先權下降得快,故后進入就緒隊列的進程此先進入的進程的優(yōu)先權高。 18 有一個四道作業(yè)的操作系統(tǒng),若在一段時間內先后到達6 個作業(yè),它們的提交和估計運行時間由下表給出: 系統(tǒng)采用SJF 調度算法,作業(yè)被調度進入系統(tǒng)后中途不會退出,但作業(yè)運行時可被更短作業(yè)搶占。(l )分別給出6 個作業(yè)的執(zhí)行時間序列、即開始執(zhí)行時間、作業(yè)完成時間、作業(yè)周轉時間。(2 )計算平均作業(yè)周轉時間。答 說明:( 1 ) J2 到達時搶占J1 ; J3 到達時搶占J2 。 ( 2 )但J4 到達時,因不滿足SJF ,故J4 不能被運行,J3 繼續(xù)執(zhí)行5 分鐘。 ( 3 )由于是4 道的作業(yè)系統(tǒng),故后面作業(yè)不能

31、進入主存而在后備隊列等待,直到有作業(yè)結束。 ( 4 )根據進程調度可搶占原則,J3 第一個做完。而這時J5 、J6 均己進入后備隊列,而J5 可進入主存。 ( 5 )因J5 最短,故它第二個完成。這時J6 方可進入主存。因J6 最短,故它第三個完成。 ( 6 )然后是:J4 、J2和J1 ( 7 ) T =( 155 + 95 + 20 + 55 + 15 + 20 ) / 6 = 60 19、有一個具有兩道作業(yè)的批處理系統(tǒng),作業(yè)調度采用短作業(yè)優(yōu)先的調度算法,進程調度采用以優(yōu)先數(shù)為基礎的搶占式調度算法,在下表所示的作業(yè)序列,作業(yè)優(yōu)先數(shù)即為進程優(yōu)先數(shù),優(yōu)先數(shù)越小優(yōu)先級越高。( 1 )列出所有作業(yè)

32、進入內存時間及結束時間。( 2 )計算平均周轉時間。答:每個作業(yè)運行將經過兩個階段:作業(yè)調度(SJF 算法)和進程調度(優(yōu)先數(shù)搶占式)。另外,批處理最多容納2 道作業(yè),更多的作業(yè)將在后備隊列等待。( l ) 10 : 00 ,作業(yè)A 到達并投入運行。 ( 3 ) 10 : 2O ,作業(yè)B 到達且優(yōu)先權高于作業(yè)A ,故作業(yè)B 投入運行而作業(yè)A 在就緒隊列等待。 ( 4 ) 10 : 30 ,作業(yè)C 到達,因內存中已有兩道作業(yè),故作業(yè)C 進入作業(yè)后備隊列等待。 ( 5 ) 10 : 50 ,作業(yè)B 運行結束,作業(yè)D 到達,按SJF 短作業(yè)優(yōu)先算法,作業(yè)D 被裝入內存進入就緒隊列。而由于作業(yè)A 的優(yōu)

33、先級高于作業(yè)D ,故作業(yè)A 投入運行 ( 6 ) 11 : 10 ,作業(yè)A 運行結束,作業(yè)C 被調入內存,具作業(yè)c 的優(yōu)先級高于作業(yè)D , 故作業(yè)C 投入運行。 ( 7 ) 12 : 00 ,作業(yè)c 運行結束,作業(yè)D 投入運行。 ( 8 ) 12 : 20 ,作業(yè)D 運行結束。 各作業(yè)周轉時間為:作業(yè)A 70 ,作業(yè)B 30 ,作業(yè)C 90 ,作業(yè)D 90 。平均作業(yè)周轉時間為70 分鐘。 20 、某多道程序設計系統(tǒng)供用戶使用的主存為100K ,磁帶機2 臺,打印機1 臺。采用可變分區(qū)內存管理,采用靜態(tài)方式分配外圍設備,忽略用戶作業(yè)FO 時間?,F(xiàn)有作業(yè)序列如下: 作業(yè)調度采用FCFS 策略,優(yōu)

34、先分配主存低地址區(qū)且不準移動已在主存的作業(yè),在主存中的各作業(yè)平分CPU 時間現(xiàn)求:( l )作業(yè)被調度的先后次序?( 2 )全部作業(yè)運行結束的時間?( 3 )作業(yè)平均周轉時間為多少?( 4 )最大作業(yè)周轉時間為多少? 答:( l )作業(yè)調度選擇的作業(yè)次序為:作業(yè)1 、作業(yè)3 、作業(yè)4 、作業(yè)2 和作業(yè)5 . ( 2 )全部作業(yè)運行結束的時間9 : 30 。 ( 3 )周轉時間:作業(yè)1 為30 分鐘、作業(yè)2 為55 分鐘、作業(yè)3 為40 分鐘、作業(yè)4 為40 分鐘和作業(yè)5 為55 分鐘。 ( 4 )平均作業(yè)周轉時間44 分鐘。 ( 5 )最大作業(yè)周轉時間為55 分鐘。 分析:本題綜合測試了作業(yè)調

35、度、進程調度、及對外設的競爭、主存的競爭。8 : oo 作業(yè)1 到達,占有資源并調入主存運行。 8 : 20 作業(yè)2 和3 同時到達,但作業(yè)2 因分不到打印機,只能在后備隊列等待。作業(yè)3 資源滿足,可進主存運行,并與作業(yè)1 平分CPU 時間。 8 : 30 作業(yè)1 在8 : 30 結束,釋放磁帶與打印機。但作業(yè)2 仍不能執(zhí)行,因不能移動而沒有30KB 的空閑區(qū),繼續(xù)等待。作業(yè)4 在8 : 30 到達,并進入主存執(zhí)行,與作業(yè)3 分享CPU8 : 35 作業(yè)5 到達,因分不到磁帶/打印機,只能在后備隊列等待。 9 : 00 作業(yè)3 運行結束,釋放磁帶機。此時作業(yè)2 的主存及打印機均可滿足,投入運行

36、。作業(yè)5 到達時間晚,只能等待。 9 : 10 作業(yè)4 運行結束,作業(yè)5 因分不到打印機,只能在后備隊列繼續(xù)等待。 9:15巧作業(yè)2 運行結束,作業(yè)5 投入運行。 9 : 30 作業(yè)全部執(zhí)行結束。 21、某多道程序設計系統(tǒng)采用可變分區(qū)內存管理,供用戶使用的主存為200K ,磁帶機5 臺。采用靜態(tài)方式分配外圍設備,且不能移動在主存中的作業(yè),忽略用戶作業(yè)I/O時間?,F(xiàn)有作業(yè)序列如下:現(xiàn)求:( l ) FIFO 算法選中作業(yè)執(zhí)行的次序及作業(yè)平均周轉時間?( 2 ) SJF 算法選中作業(yè)執(zhí)行的次序及作業(yè)平均周轉時間?(進程調度也采用FCFS ) 答:( 1 ) FIFO 算法選中作業(yè)執(zhí)行的次序為:A

37、、B 、D 、C 和E 作業(yè)平均周轉時間為63分鐘 ( 2 ) SJF 算法選中作業(yè)執(zhí)行的次序為:A 、B 、D 、E 和C 。作業(yè)平均周轉時間為58分鐘 詳細說明:1 先來先服務算法。說明:( 1 ) 8 : 30 作業(yè)A 到達并投入運行。注意它所占用的資源。( 2 ) 8 : 50 作業(yè)B 到達,資源滿足進主存就緒隊列等CPu 。( 3 ) 9 : 00 作業(yè)C 到達,主存和磁帶機均不夠,進后備作業(yè)隊列等待。( 4 ) 9 : 05 作業(yè)D 到達,磁帶機不夠,進后備作業(yè)隊列等待。后備作業(yè)隊列有C 、D 。( 5 ) 9 : 10 作業(yè)A 運行結束,歸還資源磁帶,但注意主存不能移動(即不能緊

38、縮)。作業(yè)B 投入運行。作業(yè)C 仍因主存不夠而等在后備隊列。這時作業(yè)E 也到達了,。也由于主存不夠進入后備作業(yè)隊列。此時作業(yè)D 因資源滿足(主存磁帶均滿足),進主存就緒隊列等待。后備作業(yè)隊列還有C 、E 。( 6 ) 9 : 35 作業(yè)B 運行結束,作業(yè)D 投入運行。這時作業(yè)C 因資源滿足而調入主存進就緒隊列等CPU 。而作業(yè)E 因磁帶機不夠繼續(xù)在后備作業(yè)隊列等待。( 7 ) 9 : 55 作業(yè)D 運行結束,作業(yè)C 投入運行。這時作業(yè)E 因資源滿足而調入主存進就緒隊列等CPU 。( 8 ) 10 : 30 作業(yè)C 運行結束,、作業(yè)E 投入運行。( 9 ) 10 : 40 作業(yè)E 運行結束。2

39、短作業(yè)優(yōu)先算法。說明:( 1 ) 8 : 30 作業(yè)A 到達并投入運行。注意它所占用的資源。 ( 2 ) 8 : 50 作業(yè)B 到達,資源滿足進主存就緒隊列等CPU 。 ( 3 ) 9 : 00 作業(yè)C 到達,主存和磁帶機均不夠,進后備作業(yè)隊列等待。 ( 4 ) 9 : 05 作業(yè)D 到達,磁帶機不夠,進后備作業(yè)隊列等待。后備作業(yè)隊列有C 、D . ( 5 ) 9 : 10 作業(yè)A 運行結束,歸還資源磁帶,但注意主存不能移動(即不能緊縮)。作業(yè)B 投入運行。作業(yè)C 仍因主存不夠而等在后備隊列。這時作業(yè)E 也到達了,雖然該作業(yè)最短,也由于主存不夠進入后備作業(yè)隊列此時作業(yè)D 因資源滿足(主存磁帶均

40、滿腳,進主存就緒隊列等待。后備作業(yè)隊列還有C 、E 。 ( 6 ) 9 : 35 作業(yè)B 運行結束,作業(yè)D 投入運行。這時作業(yè)C 和E 資源均滿足,但按SJF 應把作業(yè)E 調入主存進就緒隊列等CPU 。而作業(yè)C 因磁帶機不夠繼續(xù)在后備作業(yè)隊列等待。 ( 7 ) 9 : 55 作業(yè)D 運行結束,作業(yè)C 調入主存進就緒隊列等CPU .( 8 ) 10 : 05 作業(yè)E 運行結束,作業(yè)C 投入運行 ( 9 ) 10 : 40 作業(yè)C 運行結束。上題中,若允許移動己在主存中的作業(yè),其他條件不變,現(xiàn)求:( l ) FIFO 算法選中作業(yè)執(zhí)行的次序及作業(yè)平均周轉時間?( 2 ) SJF 算法選中作業(yè)執(zhí)行的

41、次序及作業(yè)平均周轉時間?答:FIFO 算法選中作業(yè)執(zhí)行的次序為:SJF 算法選中作業(yè)執(zhí)行的次序為:(l ) A 、B 、D 、E 和C。作業(yè)平均周轉時間為58 分鐘。( 2 ) A 、B 、E 、D 和C。作業(yè)平均周轉時間為56 分鐘。與上題類同,詳細說明略。 23、設計一個進程定時喚醒隊列和定時喚醒處理程序:( l )說明一個等待喚醒進程入隊v 的過程。(2 )說明時鐘中斷時,定時喚醒處理程序的處理過程。(3 )現(xiàn)有進程P1 要求20 秒后運行,經過40 秒后再次運行;PZ 要求25 秒后運行;P3 要求35 秒后運行,經過35 秒后再次運行;P4 要求60 秒后運行。試建立相應的進程定時喚

42、醒隊列。答:組織如下的定時喚醒隊列 。( l )當一個需定時喚醒的進程要入隊時,根據它要喚醒的時間,被扦入隊列的適當位置,注意,喚醒時間按增量方式存放。( 2 )每當時鐘中斷時,時鐘中斷例程判別把隊列中的第一個進程的時間量減1 ,直到該值為時喚醒進程工作。同時隊列中下一個進程成為隊列頭。24、一個實時系統(tǒng)有4 個周期性事件,周期分別為50 、100 、300 和250ms 。若假設其處理分別需要35 、20 、10 和X ms,則該系統(tǒng)可調度允許的X值最大為多少?實時任務可調度應滿足: 35 / 50 +20/100 + 10/300 +X/250l X250(l-28/30) = 250&#

43、215;0.067 = 16.75ms第三章 同步、通訊與死鎖1、 有三個并發(fā)進程:R 負責從輸入設備讀入信息塊,M 負責對信息塊加工處理;P 負責打印輸出信息塊。今提供; l )一個緩沖區(qū),可放置K 個信息塊; 2 )二個緩沖區(qū),每個可放置K 個信息塊; 試用信號量和P 、V 操作寫出三個進程正確工作的流程。答:1 ) var B : array 0 , k-1 of item ; sread : semaPhore : = k ; smanage : semaPhore : = 0 ; swrite : semaphore : = 0 ; rptr : integer : = O ; mp

44、tr : integer : = O ; wptr :integer : = 0 ; x : itemcobegin process reader ; process manager ; process writer ; begin begin begin LI : read a message intox ; L2 : P ( smanage ) ; L3 : P ( swnte ) ;P ( sread ) ; x:=Bmptr; x:=Bswrite;Brptr:=x; mptr:=(mptr+1) mod k; wptr:=(wptr+1) mod k;Rptr:=(rptr+1) m

45、od k; manage the message in x; V(sread);V(smanage); Bmptr:=x; print the message in x;Goto L1; V(swrite); goto L3;End; goto L2; end;End;coend2 ) var A , B :array 0 , k -l of item ; sPut1 : semaphore:=k; SPut2: semaPhore:=k; sget1 : semaPhore : = 0 ; sget2 : semaphore : = 0 ; put1 :integer :=O ; put2:

46、integer : = 0 ; get1 :integer :=O ; get2 : integer : = O ; cobegin process reader ; processn manager; process Writer ; begin begin begin Ll : read a message into x ; L2 : P ( sgetl ) ; L3 : P ( sgetZ ) ; P ( SPut1 ) ; x : = A get1 ; x : = B get2; A put1:=x ; get1 :(get1+1 ) mod k ; get2:=(get2 + l )

47、 mod k ;Put1:=(put1+1) mod k; V(sput1); V(sput2);V(sget1); manage the message into x; print the message in x;Goto L1; P(sput2); goto L3;Put2:=(put2+1) mod k;V(sget2);Goto L2;End;Coend2 設有n 個進程共享一個互斥段,如果:( 1 )每次只允許一個進程進入互斥段;( 2 )每次最多允許m 個進程(m 簇n )同時進入互斥段。試問:所采用的信號量初值是否相同?信號量值的變化范圍如何?答:所采用的互斥信號量初值不同。1

48、 )互斥信號量初值為1 ,變化范圍為-nl , 1 。當沒有進程進入互斥段時,信號量值為1 ;當有1 個進程進入互斥段但沒有進程等待進入互斥段時,信號量值為O ;當有1 個進程進入互斥段且有一個進程等待進入互斥段時,信號量值為-1 ;最多可能有n -1 個進程等待進入互斥段,故此時信號量的值應為-(n - 1 )也就是-n+1 。 2 )互斥信號量初值為m ,變化范圍為-nm , m 。當沒有進程進入互斥段時,信號量值為m ;當有1 個進程進入互斥段但沒有進程等待進入互斥段時,信號量值為m - 1 :當有m 個進程進入互斥段且沒有一個進程等待進入互斥段時,信號量值為0 :當有m 個進程進入互斥

49、段且有一個進程等待進入互斥段時,信號量值為一l ;最多可能有n - m 個進程等待進入互斥段,故此時信號量的值應為-(n-m)也就是-n+m.3 有兩個優(yōu)先級相同的進程P1和P2,各自執(zhí)行的操作如下,信號量S1和S2初值均為0。試問Pl 、P2 并發(fā)執(zhí)行后,x 、y 、z 的值各為多少? P1: P2:Begin beginY:=1; x:=1;Y:=y+3; x:=x+5;V(S1); P(S1);Z:=Y+1; X:X+Y;P(s2); V(S2);Y:=z+y; z:=z+x;End end答:現(xiàn)對進程語句進行編號,以方便描述P1 : P2 :begin begin y : = 1 ;

50、x :=1 ; y :=y+3 ; x :x+5 ; V(S1); P(S1); Z:Y+1 ; x :XY ;P(s2); V(S2);Y:=z+y; z:=Z+X;End end 、 、 和 是不相交語句,可以任何次序交錯執(zhí)行,而結果是唯一的。接著無論系統(tǒng)如何調度進程并發(fā)執(zhí)行,當執(zhí)行到語句 時,可以得到x = 10 , y = 4 。按Bernstein 條件,語句 的執(zhí)行結果不受語句 的影響,故語句 執(zhí)行后得到z = 5 。最后,語句 和 并發(fā)執(zhí)行,這時得到了兩種結果為:語句 先執(zhí)行:x =10 , y =9 , z= 150 語句 先執(zhí)行:x =10 , y =19 , z =15此外

51、,還有第三種情況,語句 被推遲,直至語句 后再執(zhí)行,于是依次執(zhí)行以下三個語句:7 :二z + X : z : = y + 1 ; y : Z十y ; 這時z 的值只可能是y 1=5 ,故y =ZY=5 + 4=9,而x = 10 。第三種情況為:x = 10 ,Y=9 , Z = 5 。4 有一閱覽室,讀者進入時必須先在一張登記表上登記,該表為每一座位列出一個表目,包括座號、姓名,讀者離開時要注銷登記信息;假如閱覽室共有100 個座位。試用:l )信號量和P 、V 操作;2 )管程,來實現(xiàn)用戶進程的同步算法。答:1 )使用信號量和P 、v 操作:var name :array l 100of

52、A ; A = record number :integer ; name:string ; end for i : = 1 to 100 do A i .number :i;A i .name :null; mutex , seatcount : semaphore ; i : integer ;mutex : = l ; seatcount : = 100 ; cobegin process readeri ( var readename:string ) (i=1 , 2 ) P ( seatcount ) ; P (mutex ) ; for i : = 1 to 100 do i+i

53、f A i .namenull then A i .name:readername; reader get the seat number=i;/*AI.numberV ( mutex ) 進入閱覽室,座位號i ,座下讀書;P ( mutex ) ; Ainame:null ; V (mutex ) ; V(seatcount);離開閱覽室; coend2 )使用管程操作:TYPE readbook=monitor VAR R: condition ; I,seatcount :integer;name:array l:100 of string ; DEFINE rcadercome, re

54、aderleave ; USE check , wait , signal , release ; Procedure readercome ( readername ) begin check ( IM ) ; if seatcount100 wait ( R,IM ) seatcount : = seatcount + 1 ; for i=1 to 100 do i+if namei =null then namei:= readername; get the seat number = i ; release ( IM ) ; end procedure readerleave ( re

55、adername ) begin check ( IM ) ; seatcount-; for i = 1 to 1 00 do i+if namei readername then namei:null;release ( IM ) ; end begin seatcount : = 1OO ; name:null ; end cobegin process readeri ( i = 1 , 2 )begin readercome ( readername); read the book ; readerleave ( readername); leave the readroom;end

56、 coend.5. 在一個盒子里,混裝了數(shù)量相等的黑白圍棋子· 現(xiàn)在用自動分揀系統(tǒng)把黑子、白子分開,設分揀系統(tǒng)有二個進程P1 和P2 ,其中P1 揀白子;P2 揀黑子。規(guī)定每個進程每次揀一子;當一個進程在揀時,不允許另一個進程去揀;當一個進程揀了一子時,必須讓另一個進程去揀試寫出兩進程P1 和P2 能并發(fā)正確執(zhí)行的程序。答1 :實質上是兩個進程的同步問題,設信號量s1 和s2 分別表示可揀白子和黑子,不失一般性,若令先揀白子。var S1 , S2 : semaphore; S1 : = l; S2 :=0;cobegin process P1 begin repeat P( S1 ) ; 揀白子V ( S

溫馨提示

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

評論

0/150

提交評論