版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 操作系統(tǒng)課程設(shè)計(jì)報(bào)告</p><p> 題 目: 進(jìn)程調(diào)度算法 </p><p> Minix操作系統(tǒng)實(shí)踐 </p><p> 姓 名: ********* </p><p> 學(xué) 號(hào):
2、 ********* </p><p> 專 業(yè): 計(jì)算機(jī)科學(xué)與技術(shù) </p><p> 指導(dǎo)教師: ***** </p><p><b> 實(shí)驗(yàn)一</b></p><p><b> 1.實(shí)驗(yàn)?zāi)康?lt;/b>
3、;</p><p> 通過(guò)優(yōu)先權(quán)法和輪轉(zhuǎn)算法的模擬加深對(duì)進(jìn)程概念和進(jìn)程調(diào)度過(guò)程的理解,掌握進(jìn)程狀態(tài)之間的切換,同時(shí)掌握進(jìn)程調(diào)度算法的實(shí)現(xiàn)方法和技巧。</p><p><b> 2.實(shí)驗(yàn)內(nèi)容</b></p><p> 1.用C++語(yǔ)言來(lái)實(shí)現(xiàn)對(duì)n個(gè)進(jìn)程采用優(yōu)先權(quán)優(yōu)先算法以及輪轉(zhuǎn)算法的進(jìn)程調(diào)度。</p><p> 2.
4、每個(gè)用來(lái)標(biāo)識(shí)進(jìn)程的進(jìn)程控制塊PCB用結(jié)構(gòu)來(lái)描述,包括以下字段:</p><p> ?。?)進(jìn)程標(biāo)識(shí)ID,其中0為閑逛進(jìn)程,用戶進(jìn)程的標(biāo)識(shí)數(shù)為1,2,3…。</p><p> ?。?)進(jìn)程優(yōu)先級(jí)Priority,閑逛進(jìn)程(idle)的優(yōu)先級(jí)為0,用戶進(jìn)程的優(yōu)先級(jí)大于0,且隨機(jī)產(chǎn)生,標(biāo)識(shí)數(shù)越大,優(yōu)先級(jí)越高。</p><p> ?。?)進(jìn)程占用的CPU時(shí)間CPUtime,
5、進(jìn)程每運(yùn)行一次,累計(jì)值等于4。</p><p> ?。?)進(jìn)程總共需要運(yùn)行時(shí)間Alltime,利用隨機(jī)函數(shù)產(chǎn)生。</p><p> ?。?)進(jìn)程狀態(tài),0-就緒態(tài);1-運(yùn)行態(tài);2-阻塞態(tài)。</p><p> ?。?)隊(duì)列指針next,用來(lái)將多個(gè)進(jìn)程控制塊PCB鏈接為隊(duì)列。</p><p> 3.優(yōu)先數(shù)改變的原則</p><
6、p> (1)進(jìn)程在就緒隊(duì)列中每呆一個(gè)時(shí)間片,優(yōu)先數(shù)增加1。</p><p> ?。?)進(jìn)程每運(yùn)行一個(gè)時(shí)間片,優(yōu)先數(shù)減3。</p><p> 4.在調(diào)度前,系統(tǒng)中擁有的進(jìn)程數(shù)PCB_number由鍵盤輸入,經(jīng)初始化后,所有的進(jìn)程控制塊PCB鏈接成就緒隊(duì)列。</p><p> 5.為了清楚地觀察諸進(jìn)程的調(diào)度過(guò)程,程序應(yīng)將每個(gè)時(shí)間片內(nèi)的進(jìn)程的情況顯示出來(lái), &
7、lt;/p><p><b> 3.實(shí)驗(yàn)步驟</b></p><p><b> 進(jìn)程調(diào)度的思想</b></p><p> ?。?)當(dāng)系統(tǒng)空閑(就緒隊(duì)列為空)時(shí),系統(tǒng)運(yùn)行閑逛進(jìn)程,否則運(yùn)行其他進(jìn)程,發(fā)生變遷1(就緒→運(yùn)行)。</p><p> ?。?)在運(yùn)行進(jìn)程(包括閑逛進(jìn)程)的過(guò)程中,可能發(fā)生變遷2(
8、運(yùn)行→阻塞),即將運(yùn)行進(jìn)程插入到阻塞隊(duì)列(閑逛進(jìn)程不能被阻塞),可能有其他新的進(jìn)程創(chuàng)建PCB,還可能喚醒阻塞隊(duì)列中的某些進(jìn)程PCB,發(fā)生變遷3(阻塞→就緒),即從阻塞隊(duì)列中移出并插入就緒隊(duì)列中。</p><p> ?。?)時(shí)間片運(yùn)行結(jié)束后,若進(jìn)程累計(jì)占用CPU時(shí)間大于等于進(jìn)程需要運(yùn)行的時(shí)間,則進(jìn)程執(zhí)行結(jié)束,釋放其PCB。若進(jìn)程累計(jì)占用CPU時(shí)間小于進(jìn)程需要運(yùn)行時(shí)間,發(fā)生變遷4(運(yùn)行→就緒),即將當(dāng)前運(yùn)行的進(jìn)程插入
9、就緒隊(duì)列中。</p><p><b> 程序流程圖</b></p><p> 動(dòng)態(tài)優(yōu)先權(quán)的進(jìn)程調(diào)度算法模擬流程</p><p> 2.輪轉(zhuǎn)法進(jìn)程調(diào)度算法模擬流程</p><p><b> 程序代碼</b></p><p> /*以下程序在C++環(huán)境調(diào)試通過(guò)*/<
10、;/p><p> #define NULL 0</p><p> #include <stdio.h></p><p> #include <stdlib.h></p><p> #include<iostream></p><p> using namespace std
11、;</p><p> /*以下僅列出動(dòng)態(tài)優(yōu)先權(quán)的進(jìn)程調(diào)度算法模擬*/</p><p> /*進(jìn)程PCB結(jié)構(gòu)*/</p><p> struct Pcb</p><p><b> {</b></p><p> int ID;//進(jìn)程標(biāo)識(shí)ID,其中0為閑逛進(jìn)程,用戶進(jìn)程的標(biāo)識(shí)數(shù)為1,2,3…
12、</p><p> int priority;//進(jìn)程優(yōu)先級(jí)Priority,閑逛進(jìn)程(idle)的優(yōu)先級(jí)為0,用戶進(jìn)程的優(yōu)先級(jí)大于0,且隨機(jī)產(chǎn)生,標(biāo)識(shí)數(shù)越大,優(yōu)先級(jí)越高。</p><p> int CPUtime;//進(jìn)程占用的CPU時(shí)間CPUtime,進(jìn)程每運(yùn)行一次,累計(jì)值等于4</p><p> int ALLtime;//進(jìn)程總共需要運(yùn)行時(shí)間Allti
13、me</p><p> int State;//進(jìn)程狀態(tài),0-就緒態(tài);1-運(yùn)行態(tài);2-阻塞態(tài)。</p><p> struct Pcb *next;//隊(duì)列指針next,用來(lái)將多個(gè)進(jìn)程控制塊PCB鏈接為隊(duì)列</p><p><b> };</b></p><p> typedef struct Pcb PCB;&
14、lt;/p><p> void init(); /*產(chǎn)生idle進(jìn)程,輸入用戶進(jìn)程數(shù)目,調(diào)用insert()*/</p><p> void print(PCB *pcb); /*輸出進(jìn)程屬性信息*/</p><p> void print_init(PCB *pcb); /*輸出所有PCB的初始值*/</p&g
15、t;<p> void insert_queue(PCB *queue,PCB *item); /*動(dòng)態(tài)優(yōu)先權(quán)調(diào)試算法將item插入到隊(duì)列中,使得插入后,隊(duì)列中按照優(yōu)先級(jí)從高到低有序*/</p><p> void insert_queue1(PCB *queue,PCB *item); /*輪轉(zhuǎn)法將item插入到隊(duì)列末尾*/</p><p> void pu
16、shback_queue(PCB *queue,PCB *item); /*將item插入到隊(duì)列的尾部*/</p><p> void insert(); /*動(dòng)態(tài)優(yōu)先權(quán)的進(jìn)程調(diào)度算法生成進(jìn)程屬性信息,插入進(jìn)程就緒隊(duì)列*/</p><p> void insert1(); /*輪轉(zhuǎn)法的進(jìn)程調(diào)度算法生成進(jìn)程屬性信息,插入進(jìn)程就緒隊(duì)列
17、*/</p><p> void run(PCB *pcb); /*運(yùn)行進(jìn)程,隨機(jī)阻塞進(jìn)程、產(chǎn)生新進(jìn)程,插入就緒隊(duì)列,喚醒阻塞進(jìn)程*/</p><p> void run1(PCB *pcb); /*輪轉(zhuǎn)法試運(yùn)行參數(shù)PCB所指的進(jìn)程*/</p><p> void block(PCB *pcb); /*調(diào)用destroy
18、(),將進(jìn)程插入阻塞隊(duì)列*/</p><p> void wakeup(); /*動(dòng)態(tài)優(yōu)先權(quán)的進(jìn)程調(diào)度算法喚醒進(jìn)程,插入就緒隊(duì)列*/</p><p> void wakeup1(); /*輪轉(zhuǎn)法的進(jìn)程調(diào)度算法喚醒進(jìn)程,插入就緒隊(duì)列*/</p><p> void proc_priority(); /
19、*優(yōu)先權(quán)調(diào)度算法模擬*/</p><p> void proc_loop(); /*輪轉(zhuǎn)法調(diào)度算法模擬*/</p><p> void update(PCB *pcb); /*更新進(jìn)程信息*/</p><p> PCB *ready_queue,*block_queue,*idleprocess; /*就緒隊(duì)列,阻塞隊(duì)列及閑逛進(jìn)
20、程指針變量*/</p><p> void main()</p><p><b> {</b></p><p><b> int i=0;</b></p><p><b> while(1)</b></p><p><b> {<
21、;/b></p><p> cout<<("\n Please select a number (1,2,0) ");</p><p> cout<<("\n 1-- priority ");</p><p> cout<<("\n 2-- loop");&l
22、t;/p><p> cout<<("\n 0-- exit\n");</p><p><b> cin>>i;</b></p><p><b> if(i==1)</b></p><p><b> {</b></p>
23、<p> cout<<("\nThis is an example for priority processing:\n");</p><p><b> init();</b></p><p> ::proc_priority();</p><p><b> }</b>&
24、lt;/p><p> else if (i==2)</p><p><b> {</b></p><p> cout<<("\nThis is an example for round robin processing:\n");</p><p><b> init();&l
25、t;/b></p><p> proc_loop();</p><p><b> }</b></p><p> else if(i==0)</p><p><b> exit(1);</b></p><p><b> }</b></
26、p><p><b> }</b></p><p> /*輸出所有PCB的初始值,此函數(shù)用于測(cè)試程序*/</p><p> void print_init(PCB *pcb)</p><p><b> {</b></p><p> PCB *temp=pcb->ne
27、xt;</p><p> cout<<("\n ID priority CPUtime ALLtime State\n");</p><p> while(temp!=NULL)</p><p><b> {</b></p><p> cout<
28、;<"\n"<<" "<<temp->ID<<" "<<temp->priority<<" "<<temp->CPUtime<<" "<<temp->ALLt
29、ime;</p><p> if (temp->State==0)</p><p> cout<<(" ready");</p><p> else if (temp->State==1)</p><p> cout<<(" runn
30、ing");</p><p><b> else</b></p><p> cout<<(" blocked");</p><p> temp=temp->next;</p><p><b> }</b></p>
31、<p><b> }</b></p><p> /*輸出進(jìn)程屬性信息*/</p><p> void print(PCB *pcb)</p><p><b> {</b></p><p> PCB *temp;</p><p><b> te
32、mp=pcb;</b></p><p> if (pcb->ID==0) </p><p> cout<<("\n\tThe idle process is running!");</p><p><b> else</b></p><p><b> {
33、</b></p><p> cout<<"\n"<<" "<<temp->ID<<" "<<temp->priority<<" "<<temp->CPUtime<<&
34、quot; "<<temp->ALLtime;</p><p> if (temp->State==0)</p><p> cout<<(" ready");</p><p> else if (temp->State==1)</p><
35、p> cout<<(" running");</p><p><b> else</b></p><p> cout<<(" blocked");</p><p><b> }</b></p>&
36、lt;p><b> }</b></p><p> void insert_queue(PCB *queue,PCB *item)</p><p> {//動(dòng)態(tài)優(yōu)先權(quán)調(diào)試算法將item插入到隊(duì)列中,使得插入后,隊(duì)列中按照優(yōu)先級(jí)從高到低有序</p><p> PCB *p,*q;</p><p> q=que
37、ue;p=q->next;</p><p> while(p!=0 &&p->priority>=item->priority )</p><p><b> {</b></p><p><b> q=p;</b></p><p> p=p->ne
38、xt;</p><p><b> }</b></p><p><b> if(p==0)</b></p><p><b> {//在隊(duì)尾插入</b></p><p> item->next=0;</p><p> q->next=i
39、tem;</p><p><b> }</b></p><p><b> else</b></p><p> {//在q之后、p之前插入</p><p> item->next=p;</p><p> q->next=item;</p>&
40、lt;p><b> }</b></p><p><b> }</b></p><p> void insert_queue1(PCB *queue,PCB *item)</p><p> {//輪轉(zhuǎn)法將item插入到隊(duì)列末尾</p><p> PCB *p,*q;</p>
41、<p> q=queue;p=q->next;</p><p> item->next=0;</p><p> q->next=item;</p><p><b> }</b></p><p> void pushback_queue(PCB *queue,PCB *item)&
42、lt;/p><p> {//將item插入到隊(duì)列的尾部</p><p> PCB *p,*q;</p><p> q=queue;p=q->next;</p><p> while(p!=0 )</p><p><b> {</b></p><p><b&
43、gt; q=p;</b></p><p> p=p->next;</p><p><b> }</b></p><p> item->next=q->next;</p><p> q->next=item;</p><p><b> }&l
44、t;/b></p><p> void sort_queue(PCB *&queue)</p><p> {//對(duì)queue中的結(jié)點(diǎn)進(jìn)行排序,按照優(yōu)先級(jí)從大到小</p><p> PCB *temp=new PCB;</p><p> temp->next=0;</p><p> whil
45、e(queue->next)</p><p><b> {</b></p><p><b> PCB *p;</b></p><p> p=queue->next;queue->next=p->next;</p><p> ::insert_queue(temp,p)
46、;</p><p><b> }</b></p><p> queue->next=temp->next;</p><p> delete temp;</p><p><b> }</b></p><p> /*動(dòng)態(tài)優(yōu)先權(quán)的進(jìn)程調(diào)度生成進(jìn)程屬性信息,插入
47、進(jìn)程就緒隊(duì)列,顯示進(jìn)程信息*/</p><p> void insert()</p><p><b> {</b></p><p> PCB *newp=0;</p><p> static long id=0;</p><p> newp=new PCB;</p><
48、;p><b> id++;</b></p><p> newp->ID=id;</p><p> newp->State=0;</p><p> newp->CPUtime=0;</p><p> newp->priority=rand()%3+1;</p><
49、p> newp->ALLtime=rand()%3+1;</p><p> newp->next=NULL;</p><p> ::pushback_queue(ready_queue,newp);//將新生成進(jìn)程插入到就緒隊(duì)列尾部</p><p> print(newp);</p><p> cout<&l
50、t;("\t建立: Creating -> ready\n");</p><p><b> }</b></p><p> /*輪轉(zhuǎn)法的進(jìn)程調(diào)度生成進(jìn)程屬性信息,插入進(jìn)程就緒隊(duì)列,顯示進(jìn)程信息*/</p><p> void insert1()</p><p><b> {<
51、;/b></p><p> PCB *newp=0;</p><p> static long id=0;</p><p> newp=new PCB;</p><p><b> id++;</b></p><p> newp->ID=id;</p><p
52、> newp->State=0;</p><p> newp->CPUtime=0;</p><p> newp->ALLtime=rand()%3+1;</p><p> newp->next=NULL;</p><p> ::pushback_queue(ready_queue,newp);//將新
53、生成進(jìn)程插入到就緒隊(duì)列尾部</p><p> print(newp);</p><p> cout<<("\t建立: Creating -> ready\n");</p><p><b> }</b></p><p> /*生成n個(gè)進(jìn)程屬性信息,插入進(jìn)程就緒隊(duì)列,顯示進(jìn)程信息
54、*/</p><p> void insert(int n)</p><p><b> {</b></p><p> for(int i=1;i<=n;i++)</p><p><b> {</b></p><p><b> insert();<
55、;/b></p><p><b> } </b></p><p><b> }</b></p><p> /*動(dòng)態(tài)優(yōu)先權(quán)調(diào)度產(chǎn)生idle進(jìn)程,輸入用戶進(jìn)程數(shù)目,調(diào)用insert()*/</p><p> void init()</p><p><b>
56、 {</b></p><p> //為每個(gè)隊(duì)列設(shè)立頭結(jié)點(diǎn),便于插入刪除操作</p><p> block_queue=new PCB;</p><p> block_queue->next=0;</p><p> ready_queue=new PCB;</p><p> ready_qu
57、eue->next=0;</p><p> int i,pcb_number=-1;</p><p> idleprocess=NULL; /*設(shè)置閑逛進(jìn)程PCB各字段值*/</p><p> idleprocess=(PCB *)malloc(sizeof(PCB));</p><p> idleproce
58、ss->ID=0;</p><p> idleprocess->State=0;</p><p> idleprocess->CPUtime=0;</p><p> idleprocess->priority=0;</p><p> idleprocess->ALLtime=1;</p>&
59、lt;p> idleprocess->next=NULL;</p><p> //閑逛進(jìn)程放入就緒隊(duì)列</p><p> idleprocess->next=ready_queue->next;</p><p> ready_queue->next=idleprocess; </p><p> //也可
60、假定初始時(shí)系統(tǒng)中只有一個(gè)idle進(jìn)程</p><p> ////輸入初始時(shí)進(jìn)程的個(gè)數(shù)</p><p> //while (pcb_number<0)</p><p><b> //{</b></p><p> //cout<<("Input the number of the PCB
61、 to be started:");</p><p> //cin>>pcb_number;</p><p><b> //}</b></p><p> //cout<<("\n ID priority CPUtime ALLtime State");
62、</p><p> //for (i=0;i<pcb_number;i++)</p><p> //insert();</p><p> cout<<"就緒隊(duì)列初始化成功"<<endl;</p><p> ::print_init(ready_queue);</p>&
63、lt;p> cout<<endl;</p><p><b> }</b></p><p> /*調(diào)用destroy(),將進(jìn)程插入阻塞隊(duì)列*/</p><p> void block(PCB *pcb)</p><p> {//將pcb插入到阻塞隊(duì)列</p><p>
64、 pcb->State=2; /*將PCB所指進(jìn)程的狀態(tài)設(shè)置為阻塞*/</p><p> pcb->CPUtime-=2; /*設(shè)進(jìn)程執(zhí)行半個(gè)時(shí)間片單位后被阻塞*/</p><p> /*pcb->next=NULL;*/</p><p> print(pcb);</p><p>
65、; cout<<(" 變遷2:running -> blocked\n");</p><p> //將pcb插入到阻塞隊(duì)列</p><p> //按照什么方式插入呢,需要參考喚醒條件</p><p> //因?yàn)槭请S機(jī)喚醒一個(gè)進(jìn)程,所以我們就簡(jiǎn)單地把它放置在阻塞隊(duì)列的頭部</p><p>
66、 pcb->next=block_queue->next;</p><p> block_queue->next=pcb;</p><p><b> }</b></p><p> void update(PCB *pcb)</p><p> {//就緒隊(duì)列中進(jìn)程的優(yōu)先級(jí)均增加1</p&g
67、t;<p> PCB *temp=ready_queue->next;</p><p> while(temp && temp->next )</p><p> {//就緒隊(duì)列的最后一個(gè)是閑逛進(jìn)程</p><p> temp->priority++;</p><p> temp=tem
68、p->next;</p><p><b> }</b></p><p><b> }</b></p><p> /*動(dòng)態(tài)優(yōu)先權(quán)調(diào)度試運(yùn)行參數(shù)PCB所指的進(jìn)程*/</p><p> void run(PCB *pcb) </p><p
69、><b> {</b></p><p> //如果pcb是閑逛進(jìn)程,則不做處理,再次放入就緒隊(duì)列ready_queue</p><p> if(pcb->ID==0)</p><p><b> {</b></p><p> ::insert_queue(ready_queue,
70、pcb);</p><p> print(pcb);</p><p> cout<<" 變遷1:ready -> running\n";</p><p><b> }</b></p><p><b> else</b></p>&
71、lt;p> {//如果不是閑逛進(jìn)程,則進(jìn)行如下處理</p><p> pcb->State=1;/*設(shè)置該進(jìn)程的狀態(tài)為"運(yùn)行"*/</p><p> pcb->CPUtime+=4;/*累計(jì)該進(jìn)程占用CPU的時(shí)間*/</p><p> pcb->priority=pcb->priority-3; /*每運(yùn)行一
72、個(gè)時(shí)間片,其優(yōu)先數(shù)減3*/</p><p> if(pcb->priority<1)pcb->priority=1;</p><p> print(pcb);</p><p> printf(" 變遷1:ready -> running\n");</p><p> if (rand
73、()%3==1 ) /*PCB不是閑逛進(jìn)程,滿足條件則阻塞此進(jìn)程*/</p><p><b> {</b></p><p> if(pcb->CPUtime-2<pcb->ALLtime)</p><p> block(pcb);</p><p><b> else</b>
74、;</p><p> {//已經(jīng)執(zhí)行完畢,應(yīng)該銷毀進(jìn)程</p><p> cout<<endl;</p><p> cout<<"\t the process no "<<pcb->ID<<" is completed! 銷毀:running->Destroy&q
75、uot;<<endl;</p><p> delete pcb;</p><p><b> }</b></p><p><b> }</b></p><p><b> else</b></p><p> {//否則看改進(jìn)程是否執(zhí)行完
76、畢,如果執(zhí)行完,則釋放,否則再次放入就緒隊(duì)列</p><p> if(pcb->CPUtime>=pcb->ALLtime)</p><p><b> {//釋放</b></p><p> cout<<endl;</p><p> cout<<"\t the p
77、rocess no "<<pcb->ID<<" is completed! 銷毀:running->Destroy"<<endl;</p><p> delete pcb;</p><p><b> }</b></p><p><b> els
78、e</b></p><p> {//再次放入就緒隊(duì)列,按照優(yōu)先級(jí)有序</p><p> ::insert_queue(ready_queue,pcb);</p><p><b> }</b></p><p><b> }</b></p><p><b
79、> }</b></p><p> update(ready_queue);/*更新就緒隊(duì)列進(jìn)程優(yōu)先數(shù)*/</p><p> if (rand()%5==1)</p><p><b> {</b></p><p> insert(3); /*創(chuàng)建3個(gè)新進(jìn)程*/</p>&l
80、t;p> ::sort_queue(ready_queue);</p><p><b> }</b></p><p> if (rand()%7==1)</p><p> wakeup(); /*喚醒一個(gè)進(jìn)程*/ </p><p> /*返回當(dāng)前進(jìn)程是否被阻塞,
81、1(已阻塞),0(未阻塞)*/</p><p><b> }</b></p><p> /*輪轉(zhuǎn)法試運(yùn)行參數(shù)PCB所指的進(jìn)程*/</p><p> void run1(PCB *pcb) </p><p><b> {</b></p><
82、p> //如果pcb是閑逛進(jìn)程,則不做處理,再次放入就緒隊(duì)列ready_queue</p><p> if(pcb->ID==0)</p><p><b> {</b></p><p> ::insert_queue1(ready_queue,pcb);</p><p> print(pcb);&l
83、t;/p><p> cout<<" 變遷1:ready -> running\n";</p><p><b> }</b></p><p><b> else</b></p><p> {//如果不是閑逛進(jìn)程,則進(jìn)行如下處理</p>
84、<p> pcb->State=1;/*設(shè)置該進(jìn)程的狀態(tài)為"運(yùn)行"*/</p><p> pcb->CPUtime+=4;/*累計(jì)該進(jìn)程占用CPU的時(shí)間*/</p><p> //if(pcb->priority<1)pcb->priority=1;</p><p> //print(pcb);
85、</p><p> // printf(" 變遷1:ready -> running\n");</p><p> if (rand()%3==1 ) /*PCB不是閑逛進(jìn)程,滿足條件則阻塞此進(jìn)程*/</p><p><b> {</b></p><p> if(pcb-&g
86、t;CPUtime-2<pcb->ALLtime)</p><p> block(pcb);</p><p><b> else</b></p><p> {//已經(jīng)執(zhí)行完畢,應(yīng)該銷毀進(jìn)程</p><p> cout<<endl;</p><p> cout<
87、;<"\t the process no "<<pcb->ID<<" is completed! 銷毀:running->Destroy"<<endl;</p><p> delete pcb;</p><p><b> }</b></p><
88、p><b> }</b></p><p><b> else</b></p><p> {//否則看改進(jìn)程是否執(zhí)行完畢,如果執(zhí)行完,則釋放,否則再次放入就緒隊(duì)列</p><p> if(pcb->CPUtime>=pcb->ALLtime)</p><p><b
89、> {//釋放</b></p><p> cout<<endl;</p><p> cout<<"\t the process no "<<pcb->ID<<" is completed! 銷毀:running->Destroy"<<endl;&l
90、t;/p><p> delete pcb;</p><p><b> }</b></p><p><b> else</b></p><p> {//再次放入就緒隊(duì)列</p><p> ::insert_queue1(ready_queue,pcb);</p>
91、;<p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> if (rand()%5==1)</p><p><b> {</b></p><p&
92、gt; insert(3); /*創(chuàng)建3個(gè)新進(jìn)程*/</p><p> //::sort_queue(ready_queue);</p><p><b> }</b></p><p> if (rand()%7==1)</p><p> wakeup1(); /*喚醒一
93、個(gè)進(jìn)程*/ </p><p> /*返回當(dāng)前進(jìn)程是否被阻塞,1(已阻塞),0(未阻塞)*/</p><p><b> }</b></p><p> /*喚醒,即從阻塞隊(duì)列中選擇一個(gè)PCB,且插入就緒隊(duì)列中*/</p><p> void wakeup()</p><p> {/
94、/隨機(jī)喚醒一個(gè)阻塞進(jìn)程</p><p> //這里采取的方法是遍歷阻塞隊(duì)列,每訪問(wèn)一個(gè),就產(chǎn)生一個(gè)隨機(jī)數(shù)</p><p> //如果該隨機(jī)數(shù)對(duì)20求余恰好是1,則當(dāng)前結(jié)點(diǎn)被喚醒,就要納入就緒隊(duì)列</p><p> if(block_queue->next==0)//此時(shí)沒(méi)有被阻塞的進(jìn)程,無(wú)所謂喚醒</p><p><b>
95、; return;</b></p><p> PCB *q,*p;//下面遍歷阻塞隊(duì)列,q永遠(yuǎn)指向p的前驅(qū)</p><p> while(true)</p><p><b> {</b></p><p> q=block_queue;</p><p> p=q->ne
96、xt;</p><p> while(p && rand()%20!=1)</p><p><b> {</b></p><p><b> q=p;</b></p><p> p=p->next;</p><p><b> }<
97、/b></p><p><b> if(p!=0)</b></p><p> {//p就是要喚醒的進(jìn)程</p><p> q->next=p->next;</p><p><b> break;</b></p><p><b> }<
98、;/b></p><p><b> }</b></p><p> p->State=0;</p><p> cout<<endl;</p><p> ::print(p);</p><p> cout<<" 變遷3:blocked->r
99、eady"<<endl;</p><p> ::insert_queue(ready_queue,p);</p><p><b> }</b></p><p> void wakeup1()</p><p> {//隨機(jī)喚醒一個(gè)阻塞進(jìn)程</p><p> //這里采
100、取的方法是遍歷阻塞隊(duì)列,每訪問(wèn)一個(gè),就產(chǎn)生一個(gè)隨機(jī)數(shù)</p><p> //如果該隨機(jī)數(shù)對(duì)20求余恰好是1,則當(dāng)前結(jié)點(diǎn)被喚醒,就要納入就緒隊(duì)列</p><p> if(block_queue->next==0)//此時(shí)沒(méi)有被阻塞的進(jìn)程,無(wú)所謂喚醒</p><p><b> return;</b></p><p&g
101、t; PCB *q,*p;//下面遍歷阻塞隊(duì)列,q永遠(yuǎn)指向p的前驅(qū)</p><p> while(true)</p><p><b> {</b></p><p> q=block_queue;</p><p> p=q->next;</p><p> while(p &
102、& rand()%20!=1)</p><p><b> {</b></p><p><b> q=p;</b></p><p> p=p->next;</p><p><b> }</b></p><p><b> i
103、f(p!=0)</b></p><p> {//p就是要喚醒的進(jìn)程</p><p> q->next=p->next;</p><p><b> break;</b></p><p><b> }</b></p><p><b>
104、}</b></p><p> p->State=0;</p><p> cout<<endl;</p><p> ::print(p);</p><p> cout<<" 變遷3:blocked->ready"<<endl;</p><
105、p> ::insert_queue1(ready_queue,p);</p><p><b> }</b></p><p> /*優(yōu)先權(quán)優(yōu)先調(diào)度算法*/</p><p> void proc_priority()</p><p><b> {</b></p><p
106、> ::sort_queue(ready_queue);//對(duì)queue中的結(jié)點(diǎn)進(jìn)行排序,按照優(yōu)先級(jí)從大到小</p><p> PCB *temp=0,*running=0; /*running的PCB指針*/</p><p> int times;</p><p> for(times=0;times<10;times++)<
107、/p><p><b> {</b></p><p> //找到優(yōu)先級(jí)最高的進(jìn)程,并且從隊(duì)列中刪除</p><p> cout<<"本次調(diào)度前:"<<endl;</p><p> ::print_init(ready_queue);</p><p>
108、 running=ready_queue->next; /*running指向就緒隊(duì)列隊(duì)首PCB*/</p><p> ready_queue->next=running->next;</p><p> cout<<endl;</p><p> cout<<"本次調(diào)度開(kāi)始"<<en
109、dl;</p><p> ::run(running);</p><p> cout<<"\n本次調(diào)度結(jié)束。"<<endl;</p><p><b> }</b></p><p><b> }</b></p><p> /
110、*輪轉(zhuǎn)法進(jìn)程調(diào)用算法*/</p><p> void proc_loop()</p><p><b> {</b></p><p> PCB *temp=0,*running=0; /*running的PCB指針*/</p><p> int times;</p><p>
111、 for(times=0;times<10;times++)</p><p><b> {</b></p><p> cout<<"本次調(diào)度前:"<<endl;</p><p> ::print_init(ready_queue);</p><p> runnin
112、g=ready_queue->next; /*running指向就緒隊(duì)列隊(duì)首PCB*/</p><p> ready_queue->next=running->next;</p><p> cout<<endl;</p><p> cout<<"本次調(diào)度開(kāi)始"<<endl;<
113、/p><p> ::run1(running);</p><p> cout<<"\n本次調(diào)度結(jié)束。"<<endl;</p><p><b> }</b></p><p><b> }</b></p><p> 圖0 輸入實(shí)現(xiàn)
114、調(diào)度的方法</p><p> 圖1 輸入1 在動(dòng)態(tài)優(yōu)先級(jí)調(diào)度算法下執(zhí)行</p><p><b> 圖2</b></p><p> 圖3 輸入2 在輪轉(zhuǎn)法調(diào)度算法下執(zhí)行</p><p><b> 圖4</b></p><p> 4.實(shí)驗(yàn)過(guò)程中遇到的問(wèn)題及解決方案<
115、;/p><p> 對(duì)進(jìn)程調(diào)度的思想理解不夠深刻,不知道如何實(shí)現(xiàn)對(duì)進(jìn)程優(yōu)先級(jí)的排序,以及進(jìn)程控制塊如何配置信息。在翻閱在大量書(shū)箱和同學(xué)的幫助下,解決了用動(dòng)態(tài)優(yōu)先級(jí)在方法實(shí)現(xiàn)進(jìn)程調(diào)度模擬算法。在對(duì)C++語(yǔ)言的使用尤其是在編寫代碼方面很欠缺,在組織語(yǔ)言時(shí)出錯(cuò)不斷。經(jīng)過(guò)自己的多次修改之后,程序才得以運(yùn)行。在做輪轉(zhuǎn)法實(shí)現(xiàn)的過(guò)程中,參考動(dòng)態(tài)優(yōu)先級(jí)在方法,便很容易實(shí)現(xiàn)。</p><p><b>
116、 5.課程設(shè)計(jì)總結(jié)</b></p><p> 通過(guò)本次的課程設(shè)計(jì),使我能夠正確運(yùn)用操作系統(tǒng)課程中所學(xué)的基本理論和知識(shí),加深了對(duì)進(jìn)程調(diào)度基本概念的理解,還有讓我感受很深的是對(duì)C++語(yǔ)言的應(yīng)用,由于對(duì)C++語(yǔ)言在平時(shí)運(yùn)用的不夠,在對(duì)C++語(yǔ)言的使用尤其是在編寫代碼方面很欠缺,在組織語(yǔ)言時(shí)出錯(cuò)不斷。在設(shè)計(jì)過(guò)程中,需要大量的相關(guān)資料,為了本次課程設(shè)計(jì)我在網(wǎng)上和圖書(shū)館查閱了大量資料,不斷的發(fā)現(xiàn)問(wèn)題、提出問(wèn)題
117、、解決問(wèn)題。在編程和調(diào)試的過(guò)程中,經(jīng)常會(huì)出現(xiàn)意想不到的問(wèn)題,并非每個(gè)問(wèn)題都可以從相關(guān)資料中找到解決方法,有些問(wèn)題是無(wú)法預(yù)料到的,這就需要通過(guò)自己理性的分析得出問(wèn)題的解決方案。我還希望我們可以有更多這樣的學(xué)習(xí)機(jī)會(huì),使我們的知識(shí)體系變的更加牢固。</p><p><b> 實(shí)驗(yàn)二</b></p><p> 在Windows操作系統(tǒng)上安裝Bochs虛擬機(jī)。配置Bochs
118、虛擬機(jī),并完成Minix操作系統(tǒng)的運(yùn)行。</p><p><b> 1.實(shí)驗(yàn)?zāi)康?lt;/b></p><p> 閱讀并理解Bochs虛擬機(jī)的基本概念,成功安裝Bochs虛擬機(jī)。閱讀Minix操作系統(tǒng)相關(guān)技術(shù)資料,理解Minix操作系統(tǒng)的安裝過(guò)程和Minix操作系統(tǒng)的模塊結(jié)構(gòu),實(shí)現(xiàn)Minix操作系統(tǒng)的運(yùn)行;</p><p><b>
119、2.實(shí)驗(yàn)內(nèi)容</b></p><p> Minix操作系統(tǒng)的安裝、運(yùn)行及退出</p><p><b> 3.實(shí)驗(yàn)步驟</b></p><p> 步驟一、在http://sourceforge.net地址下載Bochs-2.0.2虛擬機(jī)軟件Bochs-2.0.2.Win32-bin.zip,大小為2.55MB,將其安裝在C:\b
120、ochs-2.0.2目錄下(安裝目錄可以是任意硬盤分區(qū),本處為C盤分區(qū));</p><p> 步驟二、下載Minix操作系統(tǒng)鏡像Minix204.zip,大小為6.84MB,并用WINRAR解壓縮軟件解壓縮鏡像文件,將鏡像文件復(fù)制到C:\bochs-2.0.2\Minix204目錄下;</p><p> 步驟三、配置Minix操作系統(tǒng)的啟動(dòng)文件C:\bochs-2.0.2\Minix2
121、04\run.bat,配置內(nèi)容如下:</p><p> #設(shè)置BXSHARE環(huán)境變量</p><p> SET BXSHARE=C:\bochs-2.0.2</p><p> #將當(dāng)前目錄換到C:\Bochs-2.0.2\minix204</p><p> cd "C:\Bochs-2.0.2\minix204"&
122、lt;/p><p> #使用當(dāng)前目錄下的minix.bxrc配置文件運(yùn)行bochs</p><p> ..\bochs -q -f minix.bxrc</p><p> 步驟四、在C:\bochs-2.0.2\Minix204\目錄下配置Minix操作系統(tǒng)硬件配置文件minix.bxrc,配置內(nèi)容如下:</p><p><b>
123、 megs: 40</b></p><p> romimage: file=$BXSHARE/BIOS-bochs-latest, address=0xf0000</p><p> vgaromimage: $BXSHARE/VGABIOS-elpin-2.40</p><p> ata0-master: type=disk, path=mini
124、x.img, cylinders=200, heads=16, spt=32</p><p> log: bochsout.txt</p><p> panic: action=ask</p><p> error: action=report</p><p> info: action=report</p><p
125、> debug: action=ignore</p><p> ips: 1000000</p><p> mouse: enabled=0</p><p> user_shortcut: keys=ctrlaltdel</p><p> boot: disk</p><p> floppya: 1_
126、44=vfloppya.img, status=inserted</p><p> ata0-slave: type=cdrom, path=d:, status=inserted</p><p> 步驟五、在C:\bochs-2.0.2\Minix204\目錄下,雙擊run.bat,運(yùn)行Minix操作系統(tǒng);</p><p> 如圖3-2所示,在此處選擇使用單
127、機(jī)版的Minix,還是網(wǎng)絡(luò)版的Minix(鍵入=,選擇單機(jī)版Minix;鍵入n,選擇網(wǎng)絡(luò)版Minix)</p><p> 網(wǎng)絡(luò)版與單機(jī)版選擇界面</p><p> Minix操作系統(tǒng)登錄界面</p><p><b> 4.實(shí)驗(yàn)結(jié)果</b></p><p> 4.實(shí)驗(yàn)過(guò)程中遇到的問(wèn)題及解決方案</p>
128、<p> 在安裝Minix和配置Bochs的過(guò)程中不知道配置問(wèn)題,在老師給的參考下成功的配置了Bochs并且運(yùn)行了Minix。</p><p> 運(yùn)行Minix的過(guò)程中出現(xiàn)的命令不知道如何操作在同學(xué)的幫助下也克服了這一困難,最終實(shí)現(xiàn)了Minix的命令的運(yùn)行,并且的到了運(yùn)行界面。</p><p><b> 5.課程設(shè)計(jì)總結(jié)</b></p>
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 操作系統(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)度算法
- 進(jìn)程調(diào)度算法操作系統(tǒng)課程設(shè)計(jì) (2)
- 操作系統(tǒng)課程設(shè)計(jì)——進(jìn)程調(diào)度模擬算法
- 操作系統(tǒng)_進(jìn)程調(diào)度算法課程設(shè)計(jì)報(bào)告
- 操作系統(tǒng)課程設(shè)計(jì)——進(jìn)程調(diào)度模擬算法
- 操作系統(tǒng)進(jìn)程調(diào)度課程設(shè)計(jì)
- 操作系統(tǒng)進(jìn)程調(diào)度課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)---多級(jí)反饋隊(duì)列進(jìn)程調(diào)度算法
- 操作系統(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)度模擬設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)--進(jìn)程調(diào)度程序設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)---磁盤調(diào)度算法
- 操作系統(tǒng)課程設(shè)計(jì)---進(jìn)程調(diào)度子系統(tǒng)模擬實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)--磁盤調(diào)度算法實(shí)踐
- 操作系統(tǒng)課程設(shè)計(jì)報(bào)告--磁盤調(diào)度算法
- 操作系統(tǒng)課程設(shè)計(jì)報(bào)告--磁盤調(diào)度算法
評(píng)論
0/150
提交評(píng)論