




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
實(shí)驗(yàn)名稱:多級反饋隊列調(diào)度09091201丁奎榮一、實(shí)驗(yàn)?zāi)康模?、綜合應(yīng)用下列知識點(diǎn)設(shè)計并實(shí)現(xiàn)操作系統(tǒng)的進(jìn)程調(diào)度,進(jìn)程狀態(tài)轉(zhuǎn)換,多組級反饋隊列進(jìn)程調(diào)度算法。2、加深理解操作系統(tǒng)進(jìn)程調(diào)度的過程。3、加深理解多級反饋隊列進(jìn)程調(diào)度算法。二、實(shí)驗(yàn)內(nèi)容:1、采用一種熟悉的語言,編制程序,最好采用C/C++,界面設(shè)計可采用其它自己喜歡的語言。2、采用多級反饋隊列進(jìn)程調(diào)度算法進(jìn)行進(jìn)程調(diào)度。3、每個進(jìn)程對應(yīng)一個PCB。在PCB中包括進(jìn)程標(biāo)識符pid、進(jìn)程的狀態(tài)標(biāo)志status、進(jìn)程優(yōu)先級priority、進(jìn)程的隊列指針next和表示進(jìn)程生命周期的數(shù)據(jù)項life(在實(shí)際系統(tǒng)中不包括該項)。4、創(chuàng)建進(jìn)程時即創(chuàng)建一個PCB,各個進(jìn)程的pid都是唯一的,pid時在1到100范圍的一個整數(shù)。可以創(chuàng)建一個下標(biāo)為1到100的布爾數(shù)組,“真”表示下標(biāo)對應(yīng)的進(jìn)程號是空閑的,“假”表示下標(biāo)對應(yīng)的進(jìn)程號已分配給某個進(jìn)程。5、進(jìn)程狀態(tài)status的取值為“就緒ready”或“運(yùn)行run”,剛創(chuàng)建時,狀態(tài)為“ready”。被進(jìn)程調(diào)度程序選中后變?yōu)椤皉un”。6、進(jìn)程優(yōu)先級priority是0到49范圍內(nèi)的一個隨機(jī)整數(shù)。7、生命周期life是1到5范圍內(nèi)的一個隨機(jī)整數(shù)。8、初始化時,創(chuàng)建一個鄰接表,包含50各就緒隊列,各就緒隊列的進(jìn)程優(yōu)先級priority分別是0到49。9、為了模擬用戶動態(tài)提交任務(wù)的過程,要求動態(tài)創(chuàng)建進(jìn)程。進(jìn)入進(jìn)程調(diào)度循環(huán)后,每次按ctrl+f即動態(tài)創(chuàng)建一個過程,然后將該P(yáng)CB插入就緒隊列中。按ctrl+q退出進(jìn)程調(diào)度循環(huán)。10、在進(jìn)程調(diào)度循環(huán)中,每次選擇優(yōu)先級最大的就緒進(jìn)程來執(zhí)行。將其狀態(tài)從就緒變?yōu)檫\(yùn)行,通過延時一段時間來模擬該進(jìn)程執(zhí)行一個時間片的過程,然后優(yōu)先級減半,生命周期減一。設(shè)計圖形用戶界面GUI,在窗口中顯示該進(jìn)程和其他所有進(jìn)程的PCB內(nèi)容。如果將該運(yùn)行進(jìn)程的生命周期不為0,則重新把它變?yōu)榫途w狀態(tài),插入就緒對列中;否則該進(jìn)程執(zhí)行完成,撤銷其PCB。以上為一次進(jìn)程調(diào)度循環(huán)。四、程序主要流程圖:實(shí)驗(yàn)源程序:#include<stdio.h>#include<stdlib.h>#include<string.h>typedefstructnode/*進(jìn)程節(jié)點(diǎn)信息*/{}}}voidPrioCreate()/*創(chuàng)建就緒隊列輸入函數(shù)*/{ReadyQueue*tmp;inti;printf("輸入就緒隊列的個數(shù):\n");scanf("%d",&ReadyNum);printf("輸入每個就緒隊列的CPU時間片:\n");for(i=0;i<ReadyNum;i++){if((tmp=(ReadyQueue*)malloc(sizeof(ReadyQueue)))==NULL){perror("malloc");exit(1);}scanf("%d",&(tmp->round));/*輸入此就緒隊列中給每個進(jìn)程所分配的CPU時間片*/tmp->prio=50-tmp->round;/*設(shè)置其優(yōu)先級,時間片越高,其優(yōu)先級越低*/tmp->LinkPCB=NULL;/*初始化其連接的進(jìn)程隊列為空*/tmp->next=NULL;InsertPrio(tmp);/*按照優(yōu)先級從高到低,建立多個就緒隊列*/}}voidGetFirst(ReadyQueue*queue)/*取得某一個就緒隊列中的隊頭進(jìn)程*/{run=queue->LinkPCB;if(queue->LinkPCB!=NULL){run->state='R';queue->LinkPCB=queue->LinkPCB->next;run->next=NULL;}}voidInsertLast(PCB*in,ReadyQueue*queue)/*將進(jìn)程插入到就緒隊列尾部*/{PCB*fst;fst=queue->LinkPCB;if(queue->LinkPCB==NULL){in->next=queue->LinkPCB;queue->LinkPCB=in;}else{while(fst->next!=NULL){fst=fst->next;}in->next=fst->next;fst->next=in;}}voidProcessCreate()/*進(jìn)程創(chuàng)建函數(shù)*/{PCB*tmp;inti;printf("輸入進(jìn)程的個數(shù):\n");scanf("%d",&num);printf("輸入進(jìn)程名字和進(jìn)程所需時間:\n");for(i=0;i<num;i++){if((tmp=(PCB*)malloc(sizeof(PCB)))==NULL){perror("malloc");exit(1);}scanf("%s",tmp->name);getchar();/*吸收回車符號*/scanf("%d",&(tmp->needtime));tmp->cputime=0;tmp->state='W';tmp->prio=50-tmp->needtime;/*設(shè)置其優(yōu)先級,需要的時間越多,優(yōu)先級越低*/tmp->round=Head->round;tmp->count=0;InsertLast(tmp,Head);/*按照優(yōu)先級從高到低,插入到就緒隊列*/}}voidRoundRun(ReadyQueue*timechip)/*時間片輪轉(zhuǎn)調(diào)度算法*/{intflag=1;GetFirst(timechip);while(run!=NULL){while(flag){run->count++;run->cputime++;run->needtime--;if(run->needtime==0)/*進(jìn)程執(zhí)行完畢*/{run->state='F';InsertFinish(run);flag=0;}elseif(run->count==timechip->round)/*時間片用完*/{run->state='W';run->count=0;/*計數(shù)器清零,為下次做準(zhǔn)備*/InsertLast(run,timechip);flag=0;}}flag=1;GetFirst(timechip);}}voidMultiDispatch()/*多級調(diào)度算法,每次執(zhí)行一個時間片*/{intflag=1;intk=0;ReadyQueue*point;point=Head;GetFirst(point);while(run!=NULL){Output();if(Head->LinkPCB!=NULL)point=Head;while(flag){run->count++;run->cputime++;run->needtime--;if(run->needtime==0)/*進(jìn)程執(zhí)行完畢*/{run->state='F';InsertFinish(run);flag=0;}elseif(run->count==run->round)/*時間片用完*/{run->state='W';run->count=0;/*計數(shù)器清零,為下次做準(zhǔn)備*/if(point->next!=NULL){run->round=point->next->round;/*設(shè)置其時間片是下一個就緒隊列的時間片*/InsertLast(run,point->next);/*將進(jìn)程插入到下一個就緒隊列中*/flag=0;}else{RoundRun(point);/*如果為最后一個就緒隊列就調(diào)用時間片輪轉(zhuǎn)算法*/break;}}++k;if(k==3){ProcessCreate();}}flag=1;if(point->LinkPCB==NULL)/*就緒隊列指針下移*/point=point->next;if(point->next==NULL){RoundRun(point);break;}GetFirst(point);}}五、實(shí)驗(yàn)中遇到的問題和實(shí)驗(yàn)中的重點(diǎn)1.使用C++對于多級反饋模擬過程進(jìn)行描述,需要對計數(shù)器KillTimer();ONTIMER();進(jìn)行設(shè)計。通過在計數(shù)器中對函數(shù)run()設(shè)計并在ONTIMER()中對run函數(shù)調(diào)用從而完成多級反饋隊列運(yùn)行的模擬。在變成過程中要對ONTIMER手動映射
溫馨提示
- 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 教育熱點(diǎn)問題課件
- 教育政策宣講課件
- 【廣安】2025年四川廣安市考試招聘事業(yè)單位工作人員235人筆試歷年典型考題及考點(diǎn)剖析附帶答案詳解
- 語音音標(biāo)教學(xué)課件
- 題型4 函數(shù)圖像型計算-備戰(zhàn)2020年中考化學(xué)計算題型特訓(xùn)(原卷版)
- 早教親子活動策劃方案
- 教育活動與教學(xué)活動方案
- 明星合影活動方案
- 日常搞笑活動方案
- 春節(jié)云活動策劃方案
- 菌毒種及其樣本的管理
- 【MOOC】探秘移動通信-重慶電子工程職業(yè)學(xué)院 中國大學(xué)慕課MOOC答案
- 【五年級】語文上冊課課練
- 2020年棗莊市滕州市事業(yè)單位教師招聘考試《教育基礎(chǔ)知識》真題庫及答案解析
- 心源性暈厥課件
- DB41 2556-2023 生活垃圾焚燒大氣污染物排放標(biāo)準(zhǔn)
- 地黃種植培訓(xùn)課件
- DB11∕T 2000-2022 建筑工程消防施工質(zhì)量驗(yàn)收規(guī)范
- 《精細(xì)化工反應(yīng)安全風(fēng)險評估規(guī)范》知識培訓(xùn)
- 形勢與政策(一)學(xué)習(xí)通超星期末考試答案章節(jié)答案2024年
- 2024-2030年中國工業(yè)軟管總成行業(yè)市場發(fā)展趨勢與前景展望戰(zhàn)略分析報告
評論
0/150
提交評論