




下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
PSA優(yōu)先級(jí)調(diào)度算法(搶占式)(java)處理機(jī)調(diào)度算法:Priorityschedulingalgorithm優(yōu)先級(jí)調(diào)度算法(搶占式)運(yùn)?結(jié)果流程圖
PSA優(yōu)先級(jí)調(diào)度算法(搶占式)(java)處理機(jī)調(diào)度算法:Priorityschedulingalgorithm優(yōu)先級(jí)調(diào)度算法(搶占式)運(yùn)?結(jié)果流程圖---------------------java代碼------------------------packageoperate;importjava.util.*;/***優(yōu)先級(jí)調(diào)度算法*搶占式(單處理機(jī))*@authorymj*@Date:2019/12/1522:53*/publicclassPSA2{staticScannercin=newScanner(System.in);/**進(jìn)程控制塊*/staticclass---------------------java代碼------------------------packageoperate;importjava.util.*;/***優(yōu)先級(jí)調(diào)度算法*搶占式(單處理機(jī))*@authorymj*@Date:2019/12/1522:53*/publicclassPSA2{staticScannercin=newScanner(System.in);/**進(jìn)程控制塊*/staticclassPCBimplementsComparable<PCB>{intid;//進(jìn)程idintarriveTime;//到達(dá)時(shí)間intrunTime;//運(yùn)?時(shí)間(要求服務(wù)時(shí)間)inthasRanTime=0;//已經(jīng)運(yùn)?時(shí)間,初始值為0intPRI;//優(yōu)先級(jí)doubleresponseRatio;//響應(yīng)?=(等待時(shí)間+要求服務(wù)時(shí)間)/要求服務(wù)時(shí)間intresponseTime;//響應(yīng)時(shí)間==?次運(yùn)?時(shí)間-到達(dá)時(shí)間intturnAroundTime;//周轉(zhuǎn)時(shí)間intwaitTime;//等待時(shí)間publicPCB(intid,intarriveTime,intrunTime,intPRI){this.id=id;this.arriveTime=arriveTime;this.runTime=runTime;this.PRI=PRI;}@Override@OverridepublicintcompareTo(PCBo){//按照到達(dá)時(shí)間進(jìn)?就緒隊(duì)列returnthis.arriveTime-o.arriveTime;}}staticPCB[]pcbs;/**到達(dá)隊(duì)列*/staticQueue<PCB>queue=newPriorityQueue<>();/**計(jì)算當(dāng)前進(jìn)程響應(yīng)?*/staticvoidcalculateResponseRatio(PCBpcb,intcurrentTime){pcb.waitTime=currentTime+1-pcb.arriveTime;//等待時(shí)間pcb.responseRatio=(pcb.waitTime+pcb.runTime)*1.0/pcb.runTime;}/**初始化PCB信息*/staticvoidinitPCB(){System.out.print((輸?進(jìn)程數(shù):輸?進(jìn)程數(shù):);intnum=cin@OverridepublicintcompareTo(PCBo){//按照到達(dá)時(shí)間進(jìn)?就緒隊(duì)列returnthis.arriveTime-o.arriveTime;}}staticPCB[]pcbs;/**到達(dá)隊(duì)列*/staticQueue<PCB>queue=newPriorityQueue<>();/**計(jì)算當(dāng)前進(jìn)程響應(yīng)?*/staticvoidcalculateResponseRatio(PCBpcb,intcurrentTime){pcb.waitTime=currentTime+1-pcb.arriveTime;//等待時(shí)間pcb.responseRatio=(pcb.waitTime+pcb.runTime)*1.0/pcb.runTime;}/**初始化PCB信息*/staticvoidinitPCB(){System.out.print((輸?進(jìn)程數(shù):輸?進(jìn)程數(shù):);intnum=cin.nextInt();pcbs=newPCB[num+1];System.out.println((輸?到達(dá)時(shí)間,運(yùn)?時(shí)間,優(yōu)先級(jí)優(yōu)先級(jí));for(inti=1;i<=num;i++){System.out.print((進(jìn)程進(jìn)程+i+);pcbs[i]=newPCB(i,cin.nextInt(),cin.nextInt(),cin.nextInt());queue.offer(pcbs[i]);}}/**判斷當(dāng)前已經(jīng)到達(dá)的進(jìn)程,判斷進(jìn)程的響應(yīng)?并使之進(jìn)?就緒隊(duì)列*/staticbooleanjudge(Queue<PCB>readyQueue,intcurrentTime){booleanflag=false;//為true表?有到達(dá)的進(jìn)程while(true){PCBpcb=queue.peek();//最先到達(dá)的進(jìn)程if(pcb==null){//所有進(jìn)程都已經(jīng)進(jìn)?了就緒隊(duì)列break;}elseif(pcb.arriveTime<=currentTime){//當(dāng)前有進(jìn)程到達(dá)PCBrunPCB=queue.poll();readyQueue.offer(runPCB);//進(jìn)?就緒隊(duì)列---等待運(yùn)?flag=true;}else{//當(dāng)前沒(méi)有進(jìn)程到達(dá)break;}}returnflag;}/**進(jìn)程進(jìn)?處理機(jī)運(yùn)?,如果進(jìn)程運(yùn)?結(jié)束返回true*/staticbooleanprocessRun(PCBpcb,intcurrentTime){if(pcb.hasRanTime==0){//進(jìn)程?次運(yùn)?時(shí)間pcb.responseTime=currentTime;}pcb.hasRanTime++;//進(jìn)?處理機(jī)運(yùn)?System.out.printf((,pcb.id);if(pcb.hasRanTime==pcb.runTime){//進(jìn)程已經(jīng)結(jié)束pcb.turnAroundTime=currentTime+1-pcb.arriveTime;//周轉(zhuǎn)時(shí)間pcb.waitTime=pcb.turnAroundTime-pcb.runTime;//等待時(shí)間pcb.responseTime-=pcb.arriveTime;returntrue;}else{System.out.println();returnfalse;}}/**計(jì)算并打印就緒隊(duì)列中的進(jìn)程*//**計(jì)算并打印就緒隊(duì)列中的進(jìn)程*/staticvoidprintReadyProcess(Queue<PCB>queue,intcurrentTime){Iterator<PCB>iterator=queue.iterator();System.out.print((就緒隊(duì)列就緒隊(duì)列);while(iterator.hasNext()){PCBpcb=iterator.next();calculateResponseRatio(pcb,currentTime);System.out.printf((進(jìn)程%d優(yōu)先級(jí)優(yōu)先級(jí),pcb.id,pcb.PRI);}System.out.println();}/**處理機(jī)運(yùn)?*/staticvoidrun(){intcurrentTime=0;//當(dāng)前時(shí)間if(!queue.isEmpty()){currentTime=queue.peek().arriveTime;}/**定義就緒隊(duì)列,根據(jù)作業(yè)長(zhǎng)短低-?排序*/Queue<PCB>readyQueue=/**計(jì)算并打印就緒隊(duì)列中的進(jìn)程*/staticvoidprintReadyProcess(Queue<PCB>queue,intcurrentTime){Iterator<PCB>iterator=queue.iterator();System.out.print((就緒隊(duì)列就緒隊(duì)列);while(iterator.hasNext()){PCBpcb=iterator.next();calculateResponseRatio(pcb,currentTime);System.out.printf((進(jìn)程%d優(yōu)先級(jí)優(yōu)先級(jí),pcb.id,pcb.PRI);}System.out.println();}/**處理機(jī)運(yùn)?*/staticvoidrun(){intcurrentTime=0;//當(dāng)前時(shí)間if(!queue.isEmpty()){currentTime=queue.peek().arriveTime;}/**定義就緒隊(duì)列,根據(jù)作業(yè)長(zhǎng)短低-?排序*/Queue<PCB>readyQueue=newPriorityQueue<PCB>(newComparator<PCB>(){@Overridepublicintcompare(PCBo1,PCBo2){if(o1.PRI!=o2.PRI){return(o2.PRI-o1.PRI)>0?1:-1;}else{returno1.arriveTime-o2.arriveTime;}}});PCBrunPcb=null;System.out.println((正在運(yùn)?的進(jìn)程正在運(yùn)?的進(jìn)程);while(true){System.out.printf((,currentTime);if(queue.isEmpty()&&readyQueue.isEmpty()&&runPcb==null){System.out.println((當(dāng)前所有進(jìn)程運(yùn)?結(jié)束當(dāng)前所有進(jìn)程運(yùn)?結(jié)束);break;}else{//進(jìn)程進(jìn)?處理機(jī)運(yùn)?if(judge(readyQueue,currentTime)==true){//此時(shí)有新到的進(jìn)程//當(dāng)前處理機(jī)上的進(jìn)程就要下處理機(jī)if(runPcb!=null){//處理機(jī)占?中readyQueue.offer(runPcb);//進(jìn)?就緒隊(duì)列runPcb=null;//此時(shí)處理機(jī)為空閑}}if(runPcb!=null){//處理機(jī)上還有進(jìn)程/**在處理機(jī)中運(yùn)?進(jìn)程-->runPCB*/if(processRun(runPcb,currentTime)==true){//運(yùn)?后進(jìn)程已經(jīng)結(jié)束printReadyProcess(readyQueue,currentTime);runPcb=null;}}else{//處理機(jī)空閑runPcb=readyQueue.poll();//出就緒隊(duì)列,if(runPcb==null){//就緒隊(duì)列為空,意味著此時(shí)處理機(jī)空閑,?且沒(méi)有到達(dá)的進(jìn)程currentTime++;//處理機(jī)等待System.out.printf((處理機(jī)空閑處理機(jī)空閑);continue;//進(jìn)?下?輪}else{//出就緒隊(duì)列,上處理機(jī)運(yùn)?if(processRun(runPcb,currentTime)==true){//運(yùn)?后進(jìn)程已經(jīng)結(jié)束printReadyProcess(readyQueue,currentTime);runPcb=null;}}}}/**時(shí)間?+1*/currentTime++;}}}publicstaticvoidmain(String[]args){initPCB();System.out.println((處理機(jī)開始運(yùn)?處理機(jī)開始運(yùn)?);run();System.out.println((處理機(jī)運(yùn)?結(jié)束處理機(jī)運(yùn)?結(jié)束);showTurnAroundTime();}//周轉(zhuǎn)時(shí)間privatestaticvoidshowTurnAroundTime(){doubleaverageT=0;doubleaverageWTAT=0;double}/**時(shí)間?+1*/currentTime++;}}}publicstaticvoidmain(String[]args){initPCB();System.out.println((處理機(jī)開始運(yùn)?處理機(jī)開始運(yùn)?);run();System.out.println((處理機(jī)運(yùn)?結(jié)束處理機(jī)運(yùn)?結(jié)束);showTurnAroundTime();}//周轉(zhuǎn)時(shí)間privatestaticvoidshowTurnAroundTime(){doubleaverageT=0;doubleaverageWTAT=0;doubleaverageWT=0;System.out.println((進(jìn)程周轉(zhuǎn)時(shí)間帶權(quán)周轉(zhuǎn)時(shí)間等待時(shí)間等待時(shí)間);for(inti=1;i<pcbs.length;i++){intturnAroundTime=pcbs[i].turnAroundTime;doubleweightTurnAroundTime=turnAroundTime*1.0/pcbs[i].runTime;intwaitTime=pcbs[i].waitTime;System.out.printf((,i,turnAroundTime,weightTurnAroundTime,waitTime);averag
溫馨提示
- 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ù)網(wǎng)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 中醫(yī)推拿期末試題及答案
- 云南省隴川縣民族中學(xué)2025屆數(shù)學(xué)高二下期末綜合測(cè)試試題含解析
- 浙江省亳州市2024-2025學(xué)年物理高二下期末學(xué)業(yè)質(zhì)量監(jiān)測(cè)試題含解析
- 云南省瀘水市第一中學(xué)2024-2025學(xué)年物理高二下期末檢測(cè)模擬試題含解析
- 中衛(wèi)市第一中學(xué)2025年物理高二下期末預(yù)測(cè)試題含解析
- 鹽城市阜寧縣高一上學(xué)期期中考試化學(xué)試題
- 特色飲品店品牌授權(quán)與接手合同范本
- 彩票店合作伙伴雇傭與市場(chǎng)拓展合同
- 交通運(yùn)輸基礎(chǔ)設(shè)施建設(shè)采購(gòu)戰(zhàn)略合同
- 公寓式酒店管理租賃合同協(xié)議
- 家具供貨結(jié)算協(xié)議書
- 2025年公證員資格考試全國(guó)范圍真題及答案
- 游客自愿離團(tuán)協(xié)議書
- 2024-2025學(xué)年滬教版(五四學(xué)制)七年級(jí)英語(yǔ)下學(xué)期考點(diǎn)突破:書面表達(dá)15篇(含答案)
- 小區(qū)中控室面試題及答案
- 選擇性必修1 《當(dāng)代國(guó)際政治與經(jīng)濟(jì)》(主觀題答題模版)
- 量子光子ics在生物醫(yī)學(xué)中的應(yīng)用-全面剖析
- 2025年度手術(shù)室感染控制工作計(jì)劃
- 課標(biāo)視角下數(shù)學(xué)跨學(xué)科項(xiàng)目式學(xué)習(xí)案例設(shè)計(jì)與思考
- 國(guó)開《離散數(shù)學(xué)》大作業(yè)及答案
- 離婚協(xié)議書 標(biāo)準(zhǔn)版電子版(2025年版)
評(píng)論
0/150
提交評(píng)論