短作業(yè)優(yōu)先算法試驗報告_第1頁
短作業(yè)優(yōu)先算法試驗報告_第2頁
短作業(yè)優(yōu)先算法試驗報告_第3頁
短作業(yè)優(yōu)先算法試驗報告_第4頁
短作業(yè)優(yōu)先算法試驗報告_第5頁
已閱讀5頁,還剩2頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

實驗短作業(yè)優(yōu)先SJF進程調(diào)度算法模擬一、實驗?zāi)康哪M單處理器系統(tǒng)的進程調(diào)度,采用短作業(yè)優(yōu)先的進程調(diào)度算法作為進程設(shè)計算法,以加深對進程的概念及進程調(diào)度算法的理解.二、實驗內(nèi)容如進程信息如下:structPCBpcb[N]= {{"AAA",0,4},{"BBB",1,3},{"CCC",2,5},{"DDD",15,2},{"EEE",4,4}};進程名到達時間運行時間完成時間周轉(zhuǎn)時間A0444B1376C251614D152183E44117#include<stdio.h>#include<string.h>#include<stdlib.h>#include<conio.h>#defineN5structPCB{ charname[8]; intarrive_time; intrun_time; intfinish_time; intzhouzhuan_time; floatdaiquan_time;};floatpinjun_zhouzhuan_time;floatpinjun_daiquan_time;structPCBpcb[N]={{"DDD",3,2},{"AAA",0,4},{"BBB",1,3},{"CCC",2,5},{"EEE",4,4}};voidoutput(){printf("進程名到達時間運行時間完成時間周轉(zhuǎn)時間帶權(quán)周轉(zhuǎn)時間\n"); for(inti=0;i<N;i++) { printf("%s%d%d%d%d%f\n",pcb[i].name,pcb[i].arrive_time,pcb[i].run_time,pcb[i].finish_time,pcb[i].zhouzhuan_time,pcb[i].daiquan_time); }}voidsortPCB(){ structPCBtemp;inti,j; for(i=0;i<N-1;i++) for(j=i+1;j<N;j++) if(pcb[i].arrive_time>pcb[j].arrive_time) { temp=pcb[j]; pcb[j]=pcb[i]; pcb[i]=temp; }}voidmain(){ inti; printf("進程初始狀態(tài)\n"); output(); printf("進程按到達時間排序后的狀態(tài)\n"); sortPCB(); output(); for(i=0;i<N;i++) { //下面計算本進程的完成時間 if(i==0) pcb[i].finish_time=pcb[i].run_time+pcb[i].arrive_time; else if(pcb[i].arrive_time<pcb[i-1].finish_time) pcb[i].finish_time=pcb[i-1].finish_time+pcb[i].run_time; else pcb[i].finish_time=pcb[i].arrive_time+pcb[i].run_time; //下面計算本進程的周轉(zhuǎn)時間 pcb[i].zhouzhuan_time=pcb[i].finish_time-pcb[i].arrive_time; //下面計算本進程的帶權(quán)周轉(zhuǎn)時間pcb[i].daiquan_time=(float)pcb[i].zhouzhuan_time/pcb[i].run_time; } inttotal_zhouzhuan_time=0; floattotal_daiquan_time=0; for(i=0;i<N;i++) { total_zhouzhuan_time+=pcb[i].zhouzhuan_time; total_daiquan_time+=pcb[i].daiquan_time; } pinjun_zhouzhuan_time=(float)total_zhouzhuan_time/N; pinjun_daiquan_time=total_daiquan_time/N; printf("計算后的結(jié)果輸出\n");

溫馨提示

  • 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論