版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、操 作 系 統(tǒng)實驗報告(4)學(xué)院:計算機(jī)科學(xué)與技術(shù)學(xué)院班級:計091學(xué)號: 2姓名:時間:2011/12/31目 錄1. 實驗名稱32. 實驗?zāi)康?3. 實驗內(nèi)容34. 實驗要求35. 實驗原理36. 實驗環(huán)境47. 實驗設(shè)計47.1數(shù)據(jù)結(jié)構(gòu)設(shè)計47.2算法設(shè)計57.3功能模塊設(shè)計68. 實驗運行結(jié)果109. 實驗心得10附錄:源代碼(部分)11一、實驗名稱:用c+實現(xiàn)驅(qū)動調(diào)度算法二、實驗?zāi)康模和ㄟ^自己編程來實現(xiàn)驅(qū)動調(diào)度算法,進(jìn)一步理解驅(qū)動調(diào)度算法的概念及含義,提高對驅(qū)動調(diào)度算法的認(rèn)識,同時提高自己的動手實踐能力。加強(qiáng)我們對磁盤調(diào)度的理解,有利于我們了解先來先服務(wù)算法、最短作業(yè)優(yōu)先算法、響應(yīng)比
2、最高優(yōu)先者優(yōu)先算法。三、實驗內(nèi)容:利用c+,實現(xiàn)驅(qū)動調(diào)度算法1. 先來先服務(wù)算法(fcfs)2. 最短作業(yè)優(yōu)先算法(sjf)3. 響應(yīng)比最高優(yōu)先者優(yōu)先算法(hrrf)四、實驗要求:1.完成驅(qū)動調(diào)度算法的設(shè)計2.分別計算每種算法的經(jīng)過磁道數(shù)五、實驗原理:作為操作系統(tǒng)的輔助存儲器,用來存放文件的磁盤是一類高速大容量旋轉(zhuǎn)型存儲設(shè)備,在繁重的i/o負(fù)載下,同時會有若干傳輸請求來到并等待處理,系統(tǒng)必須采用一種調(diào)度策略,按照最佳次序執(zhí)行要求訪問的諸多請求,減少為若干i/o請求服務(wù)所需消耗的總時間。磁盤驅(qū)動調(diào)度對磁盤的效率有重要影響。磁盤驅(qū)動調(diào)度算法的好壞直接影響輔助存儲器的效率,從而影響計算機(jī)系統(tǒng)的整體效
3、率。1. 先入先出算法(fifo):總是嚴(yán)格按時間順序?qū)Υ疟P請求予以處理。算法實現(xiàn)簡單、易于理解并且相對公平,不會發(fā)生進(jìn)程餓死現(xiàn)象。但該算法可能會移動的柱面數(shù)較多并且會經(jīng)常更換移動方向,效率有待提高2. 電梯調(diào)度算法:總是將一個方向上的請求全部處理完后,才改變方向繼續(xù)處理其他請求。3. 掃描算法(scan algorithm):總是從最外向最內(nèi)(或最內(nèi)向最外)進(jìn)行掃描,然后在從最內(nèi)向最外(或最外向最內(nèi))掃描。該算法與電梯調(diào)度算法的區(qū)別是電梯調(diào)度在沒有最外或最內(nèi)的請求時不會移動到最外或最內(nèi)柱面。六、實驗環(huán)境:win-7系統(tǒng)visual c+ 6.0七、實驗設(shè)計:1.數(shù)據(jù)結(jié)構(gòu)設(shè)計定義結(jié)構(gòu)體:str
4、uct magnetichead/磁頭構(gòu)成int site;/當(dāng)前位置int count;/已掃描磁道數(shù)bool direct;/磁頭移動方向;struct range/磁盤磁道范圍int mstart;/起始值(0)int mend;/結(jié)束值();struct requestlist/請求序列int site;/請求磁道號bool state;/處理狀態(tài):true處理,false未處理;struct data/基本數(shù)據(jù)集合magnetichead magnetichead;/磁頭requestlist *requestlist;/請求序列int *executelist;/執(zhí)行序列range
5、 range;/磁盤磁道數(shù)范圍int length;/請求數(shù)量;定義類對象:class display/封裝顯示方法private:public:display()/構(gòu)造函數(shù)void displayexecutelist(data *db)/輸出執(zhí)行列cout執(zhí)行列: ;for(int i=0;ilength;i+)coutexecutelisti ;coutexecutelisti;coutendl;cout經(jīng)過磁道數(shù): magnetichead.count;coutendl;void displayrequestlist(data *db)/輸出請求列cout請求列: ;for(int i
6、=0;ilength;i+)coutrequestlisti.site ;coutendl;2.算法設(shè)計 2.1 fcfs算法void fcfs(data *db)/先來先服務(wù)算法int t=0;for(int i=0;ilength;i+)db-executelisti+1=db-requestlisti.site;db-magnetichead.site=db-requestlisti.site;t=db-executelisti-db-requestlisti.site;if(tmagnetichead.count+=t;2.2 電梯調(diào)度算法void elevator(data *db)
7、/電梯算法int *a;a=new intdb-length;for(int i = 0; ilength;i+)ai=db-requestlisti.site;int t;/冒泡排序if(db-magnetichead.direct=false)/方向從小到大for( i = 1; ilength;i+)for(int j=0;jlength-i;j+)if(ajaj+1)t=aj;aj=aj+1;aj+1=t;int j;/生成執(zhí)行序列for( i = 0; ilength;i+)if(db-magnetichead.site=ai)j=i;for(int k=0;klength;k+,i
8、+)db-executelistk+1=ai;for(int l=db-length-j+1, i = 0; iexecutelistl=aj-i-1;db-magnetichead.count=a0+db-magnetichead.site-2*adb-length-1;else /方向從大到小for( i = 1; ilength;i+)for(int j=0;jlength-i;j+)if(ajaj+1)t=aj;aj=aj+1;aj+1=t;int j;/生成執(zhí)行序列for( i = 0; ilength;i+)if(db-magnetichead.site=ai)j=i;for(in
9、t k=0;klength;k+,i+)db-executelistk+1=ai;for(int l=db-length-j+1, i = 0; iexecutelistl=aj-i-1;db-magnetichead.count=2*adb-length-1-a0-db-magnetichead.site;/計算掃描磁道數(shù)2.3 掃描算法void scan(data *db)/掃描算法int *a;a=new intdb-length;for(int i = 0; ilength;i+)ai=db-requestlisti.site;int t;if(db-magnetichead.dire
10、ct=true)for( i = 1; ilength;i+)for(int j=0;jlength-i;j+)if(ajaj+1)t=aj;aj=aj+1;aj+1=t;int j;for( i = 0; ilength;i+)if(db-magnetichead.site=ai)j=i;for(int k=0;klength;k+,i+)db-executelistk+1=ai;for(int l=db-length-j+1, i = 0; iexecutelistl=aj-i-1;db-magnetichead.count=a0+db-magnetichead.site-2*db-ran
11、ge.mstart;elsecoutaan;for( i = 1; ilength;i+)for(int j=0;jlength-i;j+)if(ajaj+1)t=aj;aj=aj+1;aj+1=t;int j;for( i = 0; ilength;i+)if(db-magnetichead.site=ai)j=i;for(int k=0;klength;k+,i+)db-executelistk+1=ai;for(int l=db-length-j+1, i = 0; iexecutelistl=aj-i-1;db-magnetichead.count=2*db-range.mend-a0
12、-db-magnetichead.site; ;3.功能模塊設(shè)計struct data/基本數(shù)據(jù)集合class display/封裝顯示方法class initdata/設(shè)置基本參數(shù)struct magnetichead/磁頭構(gòu)成class movemethod/封裝調(diào)度方法struct range/磁盤磁道范圍struct requestlist/請求序列void main() /主函數(shù)8、 實驗運行結(jié)果:1.選擇 fcfs算法實現(xiàn):2.選擇電梯調(diào)度算法實現(xiàn)3. 選擇掃描算法實現(xiàn)九、實驗心得:經(jīng)過本次實驗,我更加了解了磁盤調(diào)度算法。先來先服務(wù)算法磁盤臂是隨機(jī)移動的,進(jìn)程等待i/o請求的時間會
13、很長,尋道性較差。電梯調(diào)度算法,磁盤柱面號通常由外向里遞增,磁頭越向外,所處的柱面號越小。最短查找時間優(yōu)先算法,總是先執(zhí)行查找時間最短的請求,有較好的尋道性能。當(dāng)然在實驗過程中,我也遇到了一些困難,但是我通過及時請教同學(xué),查詢相關(guān)資料,及時解決了問題,但仍有不足之處,我將會在今后學(xué)習(xí)中更加努力。附錄:源代碼(部分)#includeusing namespace std;struct magnetichead/磁頭構(gòu)成int site;/當(dāng)前位置int count;/已掃描磁道數(shù)bool direct;/磁頭移動方向;struct range/磁盤磁道范圍int mstart;/起始值(0)in
14、t mend;/結(jié)束值();struct requestlist/請求序列int site;/請求磁道號bool state;/處理狀態(tài):true處理,false未處理;struct data/基本數(shù)據(jù)集合magnetichead magnetichead;/磁頭requestlist *requestlist;/請求序列int *executelist;/執(zhí)行序列range range;/磁盤磁道數(shù)范圍int length;/請求數(shù)量;class initdata/設(shè)置基本參數(shù)private:public:initdata()/構(gòu)造函數(shù)void setrange(data *db)/設(shè)置磁道
15、范圍int s=0,e=100;cout設(shè)置磁道范圍: n;/coutse;db-range.mstart=s;db-range.mend=e;void setrequestlist(data *db)/設(shè)置請求列int len;int site=0;coutlen;/len=10;db-length=len;db-requestlist=new requestlistlen;db-executelist=new intlen+1;for(int i=0;ilen;i+)cout設(shè)置請求 isite;db-requestlisti.site=site;for( i=0;iexecutelist
16、i= db-magnetichead.site;db-requestlist9.state=false;void setmagnetichead(data *db)/設(shè)置當(dāng)前磁道位置及方向int s,c,d;/cout預(yù)置當(dāng)前磁道位置:25, 方向: 從大到小n;c=0;/d=0;couts;coutd;db-magnetichead.site=s;db-magnetichead.count=c;db-magnetichead.direct=d;class movemethod/封裝調(diào)度方法private:public:movemethod()/構(gòu)造函數(shù)void fcfs(data *db)/
17、先來先服務(wù)算法int t=0;for(int i=0;ilength;i+)db-executelisti+1=db-requestlisti.site;db-magnetichead.site=db-requestlisti.site;t=db-executelisti-db-requestlisti.site;if(tmagnetichead.count+=t;void elevator(data *db)/電梯算法int *a;a=new intdb-length;for(int i = 0; ilength;i+)ai=db-requestlisti.site;int t;/冒泡排序i
18、f(db-magnetichead.direct=false)/方向從小到大for( i = 1; ilength;i+)for(int j=0;jlength-i;j+)if(ajaj+1)t=aj;aj=aj+1;aj+1=t;int j;/生成執(zhí)行序列for( i = 0; ilength;i+)if(db-magnetichead.site=ai)j=i;for(int k=0;klength;k+,i+)db-executelistk+1=ai;for(int l=db-length-j+1, i = 0; iexecutelistl=aj-i-1;db-magnetichead.c
19、ount=a0+db-magnetichead.site-2*adb-length-1;else /方向從大到小for( i = 1; ilength;i+)for(int j=0;jlength-i;j+)if(ajaj+1)t=aj;aj=aj+1;aj+1=t;int j;/生成執(zhí)行序列for( i = 0; ilength;i+)if(db-magnetichead.site=ai)j=i;for(int k=0;klength;k+,i+)db-executelistk+1=ai;for(int l=db-length-j+1, i = 0; iexecutelistl=aj-i-1
20、;db-magnetichead.count=2*adb-length-1-a0-db-magnetichead.site;/計算掃描磁道數(shù)void scan(data *db)/掃描算法int *a;a=new intdb-length;for(int i = 0; ilength;i+)ai=db-requestlisti.site;int t;if(db-magnetichead.direct=true)for( i = 1; ilength;i+)for(int j=0;jlength-i;j+)if(ajaj+1)t=aj;aj=aj+1;aj+1=t;int j;for( i =
21、0; ilength;i+)if(db-magnetichead.site=ai)j=i;for(int k=0;klength;k+,i+)db-executelistk+1=ai;for(int l=db-length-j+1, i = 0; iexecutelistl=aj-i-1;db-magnetichead.count=a0+db-magnetichead.site-2*db-range.mstart;elsecoutaan;for( i = 1; ilength;i+)for(int j=0;jlength-i;j+)if(ajaj+1)t=aj;aj=aj+1;aj+1=t;i
22、nt j;for( i = 0; ilength;i+)if(db-magnetichead.site=ai)j=i;for(int k=0;klength;k+,i+)db-executelistk+1=ai;for(int l=db-length-j+1, i = 0; iexecutelistl=aj-i-1;db-magnetichead.count=2*db-range.mend-a0-db-magnetichead.site; ;class display/封裝顯示方法private:public:display()/構(gòu)造函數(shù)void displayexecutelist(data *db)/輸出執(zhí)行列cout執(zhí)行列: ;for(int i=0;ilength;i+)coutexecutelisti ;coutexecutelisti;coutendl;cout經(jīng)過磁道數(shù): magnetichead.count;coutendl;void displayreque
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 廣東水利電力職業(yè)技術(shù)學(xué)院《數(shù)字邏輯設(shè)計》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東生態(tài)工程職業(yè)學(xué)院《建筑裝飾工程概預(yù)算》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東梅州職業(yè)技術(shù)學(xué)院《地下水污染與防治》2023-2024學(xué)年第一學(xué)期期末試卷
- 【2022屆走向高考】高三數(shù)學(xué)一輪(人教B版)基礎(chǔ)鞏固:第2章-第1節(jié)-函數(shù)及其表示
- 廣東省揭陽市榕城區(qū)2024-2025年第一學(xué)期期終質(zhì)量檢測小學(xué)五年級語文科試卷(有答案)
- 【金版學(xué)案】2014-2021學(xué)年高中歷史優(yōu)化訓(xùn)練(人教版必修3)第11課-物理學(xué)的重大進(jìn)展
- 【全程復(fù)習(xí)方略】2020年人教A版數(shù)學(xué)理(福建用)課時作業(yè):第十章-第九節(jié)離散型隨機(jī)變量的均值與方差
- 2022屆《創(chuàng)新設(shè)計》數(shù)學(xué)一輪課時作業(yè)(文科)(浙江專用)-第四章-三角函數(shù)、解三角形-4-2
- 四年級數(shù)學(xué)(四則混合運算)計算題專項練習(xí)與答案匯編
- 會議應(yīng)急預(yù)案策劃包括哪些內(nèi)容
- 互助資金管理辦法
- 會計學(xué)原理期末測試練習(xí)題及答案
- 金葡素注射液與血小板功能的關(guān)聯(lián)
- 澳門的英文5篇
- 2024年7月國家開放大學(xué)法律事務(wù)??啤镀髽I(yè)法務(wù)》期末紙質(zhì)考試試題及答案
- 《教師法》培訓(xùn)課件
- 財富:2024年《財富》世界500 強(qiáng)排行榜
- 常用護(hù)理評估表及注意事項
- 河北省唐山地區(qū)2023-2024學(xué)年上學(xué)期期末八年級歷史試卷
- 專題06直線與圓的位置關(guān)系、圓與圓的位置關(guān)系(課時訓(xùn)練)原卷版
- 軍用裝備信息化融合與互聯(lián)
評論
0/150
提交評論