版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 操作系統(tǒng)</b></p><p><b> 課程設(shè)計(jì)報(bào)告</b></p><p> 題目:進(jìn)程調(diào)度的模擬實(shí)現(xiàn)的模擬實(shí)現(xiàn)</p><p><b> 一、設(shè)計(jì)目的</b></p><p> 本課程設(shè)計(jì)是學(xué)習(xí)完“操作系統(tǒng)原理”課程后進(jìn)行的一次全面
2、的綜合訓(xùn)練,通過課程設(shè)計(jì),更好地掌握操作系統(tǒng)的原理及實(shí)現(xiàn)方法,加深對操作系統(tǒng)基礎(chǔ)理論和重要算法的理解,加強(qiáng)學(xué)生的動手能力。</p><p> 在多道程序和多任務(wù)系統(tǒng)中,系統(tǒng)內(nèi)同時(shí)處于就緒狀態(tài)的進(jìn)程可能有若干個(gè)。也就是說能運(yùn)行的進(jìn)程數(shù)大于處理機(jī)個(gè)數(shù)。為了使系統(tǒng)中的進(jìn)程能有條不紊地工作,必須選用某種調(diào)度策略,選擇一進(jìn)程占用處理機(jī)。要求學(xué)生設(shè)計(jì)一個(gè)模擬處理機(jī)調(diào)度算法,以鞏固和加深處理機(jī)調(diào)度的概念。</p>
3、<p><b> 二、設(shè)計(jì)內(nèi)容</b></p><p><b> 1)概述</b></p><p> 選擇一個(gè)調(diào)度算法,實(shí)現(xiàn)處理機(jī)調(diào)度。</p><p><b> 設(shè)計(jì)要求:</b></p><p> 1)進(jìn)程調(diào)度算法包括:時(shí)間片輪轉(zhuǎn)法,短作業(yè)優(yōu)先算法,
4、動態(tài)優(yōu)先級算法。</p><p><b> 2)可選擇進(jìn)程數(shù)量</b></p><p> 3)本程序包括三種算法,用C或C++語言實(shí)現(xiàn),執(zhí)行時(shí)在主界面選擇算法(可用函數(shù)實(shí)現(xiàn)),進(jìn)入子頁面后輸入進(jìn)程數(shù),(運(yùn)行時(shí)間,優(yōu)先數(shù)由隨機(jī)函數(shù)產(chǎn)生),執(zhí)行,顯示結(jié)果。</p><p><b> 2)設(shè)計(jì)原理</b></p>
5、;<p> 1.進(jìn)程控制塊的內(nèi)容如下:</p><p> 其中優(yōu)先數(shù)是賦給進(jìn)程的優(yōu)先級</p><p> 調(diào)度時(shí)總是選取優(yōu)先數(shù)最大的進(jìn)程優(yōu)先運(yùn)行</p><p> 2.每個(gè)進(jìn)程的優(yōu)先數(shù),運(yùn)行時(shí)間,由程序任意指定。</p><p> 3.為了調(diào)度方便,把進(jìn)程按給定優(yōu)先級(動態(tài)優(yōu)先級算法中)從小到大排成一個(gè)隊(duì)列。按給定運(yùn)行
6、時(shí)間(短作業(yè)優(yōu)先)從小到大排成一個(gè)隊(duì)列用一個(gè)變量作為隊(duì)首指針,指向隊(duì)列的第一個(gè)進(jìn)程。</p><p> 4.處理機(jī)調(diào)度總是選隊(duì)首進(jìn)程運(yùn)行。由于本實(shí)驗(yàn)是模擬處理機(jī)調(diào)度,所以被選中的進(jìn)程并不實(shí)際的啟動運(yùn)行,而是執(zhí)行:</p><p> 優(yōu)先數(shù)-1(動態(tài)優(yōu)先級算法中)</p><p><b> 要求運(yùn)行時(shí)間-1</b></p>&
7、lt;p> 來模擬進(jìn)程的一次運(yùn)行。</p><p> 5.進(jìn)程運(yùn)行一次后,若要求運(yùn)行時(shí)間不等于0,則再將它加入隊(duì)列(動態(tài)優(yōu)先級算法中:按優(yōu)先數(shù)大小插入。),且改變隊(duì)首指針:若要求運(yùn)行時(shí)間=0,則把它的狀態(tài)改為完成(C)狀態(tài),且退出隊(duì)列。</p><p> 6.若就緒隊(duì)列不空,則重復(fù)上述的4和5,直接所有的進(jìn)程成為完成狀態(tài)。</p><p> 7.在所設(shè)
8、計(jì)的程序中應(yīng)有顯示或打印語句,以顯示或打印每次被選中的進(jìn)程的進(jìn)程名以及運(yùn)行一次后進(jìn)程隊(duì)列的變化。</p><p><b> 3)詳細(xì)設(shè)計(jì)及編碼</b></p><p><b> 流程圖如下</b></p><p><b> 2. 實(shí)驗(yàn)分析</b></p><p> (1
9、)PCB結(jié)構(gòu)通常包括以下信息:進(jìn)程名,進(jìn)程優(yōu)先數(shù),輪轉(zhuǎn)時(shí)間片,進(jìn)程已占用的CPU時(shí)間,進(jìn)程還需要的CPU時(shí)間,進(jìn)程的狀態(tài),當(dāng)前隊(duì)列指針等??筛鶕?jù)實(shí)驗(yàn)的不同,PCB結(jié)構(gòu)的內(nèi)容可以作適當(dāng)?shù)脑鰟h</p><p> (2)本程序用兩種算法對五個(gè)進(jìn)程進(jìn)行調(diào)度,每個(gè)進(jìn)程可有三個(gè)狀態(tài):就緒、執(zhí)行、完成。并假設(shè)初始狀態(tài)為就緒狀態(tài)。 </p><p> (3)為了便于處理,程序中的某進(jìn)程運(yùn)行時(shí)間以時(shí)間片
10、為單位計(jì)算。各進(jìn)程的優(yōu)先數(shù)或輪轉(zhuǎn)時(shí)間數(shù)以及進(jìn)程需運(yùn)行的時(shí)間片數(shù)的初始值均由用戶給定。 </p><p> (4)在優(yōu)先數(shù)算法中,優(yōu)先數(shù)可以先取值為一個(gè)常數(shù)減去進(jìn)程所需要的時(shí)間片數(shù)目,進(jìn)程每執(zhí)行一次,優(yōu)先數(shù)減3,CPU時(shí)間片數(shù)加1,進(jìn)程還需要的時(shí)間片數(shù)減1。在輪轉(zhuǎn)算法中,采用固定時(shí)間片(即:每執(zhí)行一次進(jìn)程,該進(jìn)程的執(zhí)行時(shí)間片數(shù)為已執(zhí)行了2個(gè)單位),這時(shí),CPU時(shí)間片數(shù)加2,進(jìn)程還需要的時(shí)間片數(shù)減2,并排列到就緒隊(duì)
11、列的尾上。</p><p> (5)對于遇到優(yōu)先數(shù)一致的情況,采用FIFO策略解決。</p><p><b> 3.概要設(shè)計(jì)</b></p><p> (1)本程序用兩種算法對五個(gè)進(jìn)程進(jìn)行調(diào)度,每個(gè)進(jìn)程可有三個(gè)狀態(tài),并假設(shè)初始狀態(tài)為就緒狀態(tài)。</p><p> (2)為了便于處理,程序中的某進(jìn)程運(yùn)行時(shí)間以時(shí)間片為
12、單位計(jì)算。各進(jìn)程的優(yōu)先數(shù)或輪轉(zhuǎn)時(shí)間數(shù)以及進(jìn)程需運(yùn)行的時(shí)間片數(shù)的初始值均由用戶給定。</p><p> (3)在優(yōu)先數(shù)算法中,優(yōu)先數(shù)的值為50與運(yùn)行時(shí)間的差值,即P_TIME-process->needtime。進(jìn)程每執(zhí)行一次,優(yōu)先數(shù)減3,CPU時(shí)間片數(shù)加1,進(jìn)程還需要的時(shí)間片數(shù)減1。在輪轉(zhuǎn)算法中,采用固定時(shí)間片(即:每執(zhí)行一次進(jìn)程,該進(jìn)程的執(zhí)行時(shí)間片數(shù)為已執(zhí)行了2個(gè)單位),這時(shí),CPU時(shí)間片數(shù)加2,進(jìn)程還
13、需要的時(shí)間片數(shù)減2,并排列到就緒隊(duì)列的尾上。</p><p> (4)對于遇到優(yōu)先數(shù)一致的情況,采用FIFO策略解決</p><p><b> 4.詳細(xì)設(shè)計(jì)</b></p><p> (1)struct pcb() 定義pcb塊</p><p> (2)Void display() 顯示結(jié)果信息函數(shù)</p
14、><p> (3)int process_finish(pcb *q) 進(jìn)程完成標(biāo)示</p><p> (4)void display_round() 顯示循環(huán)輪轉(zhuǎn)調(diào)度算法運(yùn)行結(jié)果</p><p> (5)priority_cal() 優(yōu)先數(shù)調(diào)度算法</p><p> (6)void cpu_round()處理器的工作狀態(tài)</p&g
15、t;<p><b> 5.源程序代碼</b></p><p> #include<stdio.h> </p><p> #include <dos.h> </p><p> #include<stdlib.h> </p><p> #include<con
16、io.h> </p><p> #include<iostream.h> </p><p> #include<windows.h></p><p> #define P_NUM 5 </p><p> #define P_TIME 50 </p><p> enum state
17、</p><p><b> {</b></p><p><b> ready, </b></p><p><b> execute, </b></p><p><b> block, </b></p><p><b&g
18、t; finish</b></p><p><b> }; </b></p><p> struct pcb</p><p><b> {</b></p><p> char name[4]; </p><p> int priority; </
19、p><p> int cputime; </p><p> int needtime; </p><p> int count; </p><p> int round; </p><p> state process; </p><p> pcb * next; </p>
20、<p><b> }; </b></p><p> pcb * get_process(); </p><p> pcb * get_process()</p><p><b> { </b></p><p><b> pcb *q; </b></p
21、><p><b> pcb *t; </b></p><p><b> pcb *p; </b></p><p><b> int i=0; </b></p><p> cout<<"input name and time"<<e
22、ndl; </p><p> while (i<P_NUM){</p><p> q=(struct pcb *)malloc(sizeof(pcb)); </p><p> cin>>q->name; </p><p> cin>>q->needtime; </p><p
23、> q->cputime=0; </p><p> q->priority=P_TIME-q->needtime; </p><p> q->process=ready; </p><p> q->next=NULL; </p><p> if (i==0){ p=q; t=q;} </p&
24、gt;<p> else{t->next=q;t=q; } </p><p><b> i++; </b></p><p> } //while </p><p> return p; </p><p><b> } </b></p><p>
25、 void display(pcb *p)</p><p><b> {</b></p><p> cout<<"name"<<" "<<"cputime"<<" "<<"needtime"<<
26、" "<<"priority"<<" "<<"state"<<endl; </p><p><b> while(p)</b></p><p><b> { </b></p><p> co
27、ut<<p->name; </p><p> cout<<" "; </p><p> cout<<p->cputime; </p><p> cout<<" "; </p><p> cout<<p->needtim
28、e; </p><p> cout<<" "; </p><p> cout<<p->priority; </p><p> cout<<" "; </p><p> switch(p->process)</p><p>&
29、lt;b> { </b></p><p> case ready:cout<<"ready"<<endl;break; </p><p> case execute:cout<<"execute"<<endl;break; </p><p> case
30、block:cout<<"block"<<endl;break; </p><p> case finish:cout<<"finish"<<endl;break; </p><p><b> } </b></p><p> p=p->next;
31、 </p><p><b> } </b></p><p><b> } </b></p><p> int process_finish(pcb *q)</p><p><b> { </b></p><p> int bl=1; </
32、p><p> while(bl&&q){ </p><p> bl=bl&&q->needtime==0;</p><p> q=q->next; </p><p><b> } </b></p><p> return bl; </p>
33、;<p><b> } </b></p><p> void cpuexe(pcb *q)</p><p><b> {</b></p><p> pcb *t=q; </p><p> int tp=0; </p><p> while(q){ &
34、lt;/p><p> if (q->process!=finish)</p><p><b> {</b></p><p> q->process=ready;</p><p> if(q->needtime==0){</p><p> q->process=fini
35、sh;</p><p><b> } </b></p><p><b> } </b></p><p> if(tp<q->priority&&q->process!=finish)</p><p><b> { </b></p&
36、gt;<p> tp=q->priority;</p><p><b> t=q; </b></p><p><b> } </b></p><p> q=q->next; </p><p><b> } </b></p>&l
37、t;p> if(t->needtime!=0){</p><p> t->priority-=3; </p><p> t->needtime--; </p><p> t->process=execute; </p><p> t->cputime++; </p><p>
38、;<b> } </b></p><p><b> } </b></p><p> void priority_cal()</p><p><b> { </b></p><p><b> pcb * p; </b></p><
39、;p> system("cls");</p><p> p=get_process(); </p><p> int cpu=0; </p><p> system("cls"); </p><p> while(!process_finish(p)){ </p><
40、p><b> cpu++; </b></p><p> cout<<"cputime:"<<cpu<<endl; </p><p> cpuexe(p); </p><p> display(p); </p><p> //Sleep(100);&l
41、t;/p><p><b> getch(); </b></p><p> system("cls"); </p><p><b> } </b></p><p> printf("All processes have finished,press any key t
42、o exit"); </p><p><b> getch(); </b></p><p><b> } </b></p><p> void display_menu()</p><p><b> { </b></p><p> c
43、out<<"CHOOSE THE ALGORITHM:"<<endl; </p><p> cout<<"1 PRIORITY"<<endl; </p><p> cout<<"2 ROUNDROBIN"<<endl; </p><p&
44、gt; cout<<"3 EXIT"<<endl; </p><p><b> } </b></p><p> pcb * get_process_round()</p><p><b> { </b></p><p><b> pcb
45、 *q; </b></p><p><b> pcb *t; </b></p><p><b> pcb *p; </b></p><p><b> int i=0; </b></p><p> cout<<"input name an
46、d time"<<endl; </p><p> while (i<P_NUM){ </p><p> q=(struct pcb *)malloc(sizeof(pcb)); </p><p> cin>>q->name; </p><p> cin>>q->needt
47、ime; </p><p> q->cputime=0; </p><p> q->round=0; </p><p> q->count=0; </p><p> q->process=ready; </p><p> q->next=NULL; </p><
48、;p> if (i==0){ </p><p><b> p=q; </b></p><p><b> t=q; </b></p><p><b> } </b></p><p><b> else{ </b></p><
49、;p> t->next=q; </p><p><b> t=q; </b></p><p><b> } </b></p><p><b> i++; </b></p><p> } //while </p><p> retu
50、rn p; </p><p><b> } </b></p><p> void cpu_round(pcb *q)</p><p><b> { </b></p><p> q->cputime+=2; </p><p> q->needtime-=2
51、; </p><p> if(q->needtime<0) {</p><p> q->needtime=0; </p><p><b> } </b></p><p> q->count++; </p><p> q->round++; </p>
52、;<p> q->process=execute; </p><p><b> } </b></p><p> pcb * get_next(pcb * k,pcb * head)</p><p><b> {</b></p><p><b> pcb * t
53、; </b></p><p><b> t=k; </b></p><p><b> do{ </b></p><p> t=t->next; </p><p><b> } </b></p><p> while (t &a
54、mp;& t->process==finish); </p><p> if(t==NULL){ </p><p><b> t=head; </b></p><p> while (t->next!=k && t->process==finish){ </p><p>
55、 t=t->next; </p><p><b> } </b></p><p><b> } </b></p><p> return t; </p><p><b> } </b></p><p> void set_state(pc
56、b *p){ </p><p> while(p){ </p><p> if (p->needtime==0){ </p><p> p->process=finish; </p><p><b> } </b></p><p> if (p->process==ex
57、ecute){</p><p> p->process=ready; </p><p><b> } </b></p><p> p=p->next; </p><p><b> } </b></p><p><b> } </b>
58、</p><p> void display_round(pcb *p){ </p><p> cout<<"NAME"<<" "<<"CPUTIME"<<" "<<"NEEDTIME"<<" "
59、<<"COUNT"<<" "<<"ROUND"<<" "<<"STATE"<<endl; </p><p> while(p){ </p><p> cout<<p->name; </p>
60、;<p> cout<<" "; </p><p> cout<<p->cputime; </p><p> cout<<" "; </p><p> cout<<p->needtime; </p><p> cout&
61、lt;<" "; </p><p> cout<<p->count; </p><p> cout<<" "; </p><p> cout<<p->round; </p><p> cout<<" "; &l
62、t;/p><p> switch(p->process){</p><p> case ready:cout<<"ready"<<endl;break; </p><p> case execute:cout<<"execute"<<endl;break; </p&
63、gt;<p> case finish:cout<<"finish"<<endl;break; </p><p><b> } </b></p><p> p=p->next; </p><p><b> } </b></p><p
64、><b> } </b></p><p> void round_cal()</p><p><b> { </b></p><p><b> pcb * p; </b></p><p><b> pcb * r; </b></p&g
65、t;<p> system("cls"); </p><p> p=get_process_round();</p><p> int cpu=0; </p><p> system("cls"); </p><p><b> r=p; </b></p
66、><p> while(!process_finish(p)){ </p><p><b> cpu+=2; </b></p><p> cpu_round(r); </p><p> r=get_next(r,p); </p><p> cout<<"cpu &quo
67、t;<<cpu<<endl; </p><p> display_round(p); </p><p> set_state(p); </p><p> //Sleep(100); </p><p><b> getch();</b></p><p> syste
68、m("cls"); </p><p><b> } </b></p><p><b> } </b></p><p> void main(){ </p><p> display_menu();</p><p><b> int k;
69、 </b></p><p> scanf("%d",&k); </p><p> switch(k){ </p><p> case 1:priority_cal();break; </p><p> case 2:round_cal();break; </p><p>
70、 case 3:break; </p><p> display_menu(); </p><p> scanf("%d",&k); </p><p><b> } </b></p><p><b> }</b></p><p><
71、b> 4)結(jié)果及分析</b></p><p><b> 程序主界面</b></p><p> 運(yùn)用優(yōu)先度調(diào)度算法的執(zhí)行結(jié)果</p><p> 一直按回車到第38次運(yùn)行結(jié)束</p><p> 運(yùn)用循環(huán)輪轉(zhuǎn)調(diào)度算法的執(zhí)行結(jié)果</p><p> 一直按回車20次得到結(jié)果&l
72、t;/p><p><b> 5)設(shè)計(jì)小結(jié)</b></p><p> 處理機(jī)調(diào)度問題實(shí)際上是處理機(jī)分配問題。只有那些參與競爭處理機(jī)所必須的資源都已得到滿足的進(jìn)程才能享受競爭處理機(jī)的資格,這時(shí)它們處于內(nèi)存就緒狀態(tài)。這些必須的資源包括內(nèi)存、外設(shè)及有關(guān)數(shù)據(jù)結(jié)構(gòu)等。作業(yè)調(diào)度程序必須先調(diào)用存儲管理、外設(shè)管理,分配資源,讓它們能有競爭資格。</p><p>
73、 為了提高資源利用率,一部分在內(nèi)存中處于就緒、等待狀態(tài)而短期內(nèi)不能執(zhí)行進(jìn)程、作業(yè)換出內(nèi)存,所以外存中除了處于后備狀態(tài)的作業(yè),還有處于就緒狀態(tài)的作業(yè)。這就需要一定的方法和策略來為這部分作業(yè)分配空間。</p><p> 為期一周的課程設(shè)計(jì)課使我對處理機(jī)調(diào)度問題更進(jìn)一步的加深了了解更熟練的使用MS VC++程序,在寫代碼的過程中一開始犯了高達(dá)12個(gè)錯(cuò)誤,然后一步一步的對程序進(jìn)行修改完善最終使運(yùn)行順利得到課程設(shè)計(jì)所需
溫馨提示
- 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 操作系統(tǒng)課程設(shè)計(jì)-進(jìn)程調(diào)度模擬
- 操作系統(tǒng)課程設(shè)計(jì)---進(jìn)程調(diào)度子系統(tǒng)模擬實(shí)現(xiàn)
- 操作系統(tǒng)進(jìn)程調(diào)度課程設(shè)計(jì)報(bào)告
- 操作系統(tǒng)課程設(shè)計(jì)——進(jìn)程調(diào)度模擬算法
- 操作系統(tǒng)課程設(shè)計(jì)——進(jìn)程調(diào)度模擬算法
- 操作系統(tǒng)課程設(shè)計(jì)---進(jìn)程調(diào)度模擬設(shè)計(jì)
- 操作系統(tǒng)進(jìn)程調(diào)度課程設(shè)計(jì)
- 操作系統(tǒng)_進(jìn)程調(diào)度算法課程設(shè)計(jì)報(bào)告
- 操作系統(tǒng)進(jìn)程調(diào)度課程設(shè)計(jì)
- 進(jìn)程調(diào)度算法 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)--進(jìn)程調(diào)度算法
- 操作系統(tǒng)課程設(shè)計(jì)---進(jìn)程調(diào)度算法
- 進(jìn)程調(diào)度算法操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)--進(jìn)程調(diào)度算法
- 操作系統(tǒng)模擬進(jìn)程課程設(shè)計(jì)
- 進(jìn)程調(diào)度算法操作系統(tǒng)課程設(shè)計(jì) (2)
- 操作系統(tǒng)課程設(shè)計(jì)--進(jìn)程調(diào)度程序設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)--模擬操作系統(tǒng)的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)---作業(yè)調(diào)度模擬
- 操作系統(tǒng)程序設(shè)計(jì)課程設(shè)計(jì)報(bào)告-操作系統(tǒng)模擬實(shí)現(xiàn)
評論
0/150
提交評論