下載本文檔
版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
操作系統(tǒng)實(shí)驗(yàn)報(bào)告C語(yǔ)言實(shí)現(xiàn)銀行家算法實(shí)驗(yàn)報(bào)告題目名稱(chēng)C語(yǔ)言實(shí)現(xiàn)銀行家算法院系信息科學(xué)與工程學(xué)院班級(jí)完成時(shí)間指導(dǎo)老師本次實(shí)驗(yàn)成績(jī)組長(zhǎng)聯(lián)系電話郵件地址組員(姓名,學(xué)號(hào))主要任務(wù)程序算法的編寫(xiě)、實(shí)現(xiàn)、運(yùn)行調(diào)試組員(姓名,學(xué)號(hào))主要任務(wù)實(shí)驗(yàn)報(bào)告的完成組員(姓名,學(xué)號(hào))主要任務(wù)實(shí)驗(yàn)報(bào)告的完成組員(姓名,學(xué)號(hào))主要原理及所參考的資料(包括實(shí)驗(yàn)內(nèi)容及條件)銀行家算法原理:我們可以把操作系統(tǒng)看作是銀行家,操作系統(tǒng)管理的資源相當(dāng)于銀行家管理的資金,進(jìn)程向操作系統(tǒng)請(qǐng)求分配資源相當(dāng)于用戶(hù)向銀行家貸款。
為保證資金的安全,銀行家規(guī)定:(1)當(dāng)一個(gè)顧客對(duì)資金的最大需求量不超過(guò)銀行家現(xiàn)有的資金時(shí)就可接納該顧客;(2)顧客可以分期貸款,但貸款的總數(shù)不能超過(guò)最大需求量;(3)當(dāng)銀行家現(xiàn)有的資金不能滿(mǎn)足顧客尚需的貸款數(shù)額時(shí),對(duì)顧客的貸款可推遲支付,但總能使顧客在有限的時(shí)間里得到貸款;(4)當(dāng)顧客得到所需的全部資金后,一定能在有限的時(shí)間里歸還所有的資金.操作系統(tǒng)按照銀行家制定的規(guī)則為進(jìn)程分配資源,當(dāng)進(jìn)程首次申請(qǐng)資源時(shí),要測(cè)試該進(jìn)程對(duì)資源的最大需求量,如果系統(tǒng)現(xiàn)存的資源可以滿(mǎn)足它的最大需求量則按當(dāng)前的申請(qǐng)量分配資源,否則就推遲分配。當(dāng)進(jìn)程在執(zhí)行中繼續(xù)申請(qǐng)資源時(shí),先測(cè)試該進(jìn)程本次申請(qǐng)的資源數(shù)是否超過(guò)了該資源所剩余的總量。若超過(guò)則拒絕分配資源,若能滿(mǎn)足則按當(dāng)前的申請(qǐng)量分配資源,否則也要推遲分配。
主要參考書(shū):計(jì)算機(jī)操作系統(tǒng)第三版西安電子科技大學(xué)出版社湯子瀛主編主要算法流程圖和具體實(shí)驗(yàn)步驟主要算法流程圖和具體實(shí)驗(yàn)步驟算法流程圖:附錄1--銀行家算法流程圖附錄2--安全性算法流程圖實(shí)驗(yàn)步驟:一.銀行家算法進(jìn)程i發(fā)出請(qǐng)求資源申請(qǐng),(1)如果Request[j](2)如果:Requesti[j](3)若以上兩個(gè)條件都滿(mǎn)足,則系統(tǒng)試探著將資源分配給申請(qǐng)的進(jìn)程,并修改下面數(shù)據(jù)結(jié)構(gòu)中的數(shù)值:Available[i,j]=Available[i,j]-Request[j];Allocation[i][j]=Allocation[i][j]+Request[j];need[i][j]=need[i][j]-Request[j];(4)試分配后,執(zhí)行安全性檢查,調(diào)用check()函數(shù)檢查此次資源分配后系統(tǒng)是否處于安全狀態(tài)。若安全,才正式將資源分配給進(jìn)程;否則本次試探分配作廢,恢復(fù)原來(lái)的資源分配狀態(tài),讓該進(jìn)程等待。
(5)用do{…}while循環(huán)語(yǔ)句實(shí)現(xiàn)輸入字符y/n判斷是否繼續(xù)進(jìn)行資源申請(qǐng)。
二.安全性檢查算法(check()函數(shù))(1)設(shè)置兩個(gè)向量:工作向量Work,它表示系統(tǒng)可提供給進(jìn)程繼續(xù)運(yùn)行所需的各類(lèi)資源數(shù)目,在執(zhí)行安全性算法開(kāi)始時(shí),Work=Available。
工作向量Finish,它表示系統(tǒng)是否有足夠的資源分配給進(jìn)程,使之運(yùn)行完成。開(kāi)始時(shí)先做Finish[i]=false;當(dāng)有足夠的資源分配給進(jìn)程時(shí),再令Finish[i]=true。
(2)在進(jìn)程中查找符合以下條件的進(jìn)程:條件1:Finish[i]=false;條件2:need[i][j]程序源代碼及調(diào)試結(jié)果附錄3--程序源代碼附錄4--程序運(yùn)行調(diào)試結(jié)果實(shí)驗(yàn)心得本次實(shí)驗(yàn)我負(fù)責(zé)程序的編寫(xiě)方面,雖然基礎(chǔ)一般,但是我仍然堅(jiān)持花了三天的時(shí)間終于把程序拿下,這是讓自己很欣慰的事,本次實(shí)驗(yàn)不僅讓我對(duì)銀行家算法有了更深入的理解,并且還讓我的編程能力得到了較大提高,希望能有更多這樣的機(jī)會(huì),借此較好的鍛煉自己,從而更好的掌握和運(yùn)用自己的專(zhuān)業(yè)知識(shí),提高能力水平。
本次實(shí)驗(yàn)相對(duì)于c基礎(chǔ)并不好的我有一定的難度,所以我在程序方面所做的較少。而對(duì)銀行家算法了解的比較透徹,在程序設(shè)計(jì)的原理和流程圖方面做的工作較多,本次實(shí)驗(yàn)我學(xué)到的東西好多,也知道自己在很多方面的不足,雖然我給自己的發(fā)展方向定位為硬件方向,但是對(duì)C語(yǔ)言還是要進(jìn)一步的學(xué)習(xí)。
YNYNYNYN系統(tǒng)初始化輸入進(jìn)程個(gè)數(shù)no1輸入資源類(lèi)數(shù)no2輸入進(jìn)程最大需求矩陣Max、已分配矩陣Allocation和可利用資源矩陣Available打印輸出此時(shí)資源分配情況表Need[][]=Max[][]-Allocation[][]輸入欲申請(qǐng)資源進(jìn)程號(hào)輸入是否合法輸入該進(jìn)程申請(qǐng)的資源量Request[]>Need[][]?繼續(xù)分配(Y)?or退出(N)?Request[]>Available[][]?預(yù)分配調(diào)用check()函數(shù)進(jìn)行安全性檢查退出系統(tǒng)附錄1銀行家算法流程圖附錄2安全性算法流程圖調(diào)用check()函數(shù)work[]=available[]finish[]=falseneed[][]#include#include#definem50intno1;//進(jìn)程數(shù)intno2;//資源數(shù)intr;intallocation[m][m],need[m][m],available[m],max[m][m];charname1[m],name2[m];//定義全局變量voidmain(){voidcheck();voidprint();inti,j,p=0,q=0;charc;intrequest[m],allocation1[m][m],need1[m][m],available1[m];printf(“**********************************************\n“);printf(“*銀行家算法的設(shè)計(jì)與實(shí)現(xiàn)*\n“);printf(“**********************************************\n“);printf(“請(qǐng)輸入進(jìn)程總數(shù):\n“);scanf(“%d“,&no1);printf(“請(qǐng)輸入資源種類(lèi)數(shù):\n“);scanf(“%d“,&no2);printf(“請(qǐng)輸入Max矩陣:\n“);for(i=0;i=no1){printf(“輸入錯(cuò)誤,請(qǐng)重新輸入:\n“);continue;}elsebreak;}printf(“\n請(qǐng)輸入該進(jìn)程所請(qǐng)求的資源數(shù)request[j]:\n“);for(j=0;jneed[i][j])p=1;//判斷請(qǐng)求是否超過(guò)該進(jìn)程所需要的資源數(shù)if(p)printf(“請(qǐng)求資源超過(guò)該進(jìn)程資源需求量,請(qǐng)求失?。。躰“);else{for(j=0;javailable[j])q=1;//判斷請(qǐng)求是否超過(guò)可用資源數(shù)if(q)printf(“沒(méi)有做夠的資源分配,請(qǐng)求失?。。躰“);else//請(qǐng)求滿(mǎn)足條件{for(j=0;jc=='Y');}}voidcheck()//安全算法函數(shù){intk,f,v=0,i,j;intwork[m],a[m];boolfinish[m];r=1;for(i=0;iwork[j])f=0;if(f==1)//找到還沒(méi)有完成且需求數(shù)小于可提供進(jìn)程繼續(xù)運(yùn)行的資源數(shù)的進(jìn)程{finish[i]=true;a[v++]=i;//記錄安全序列號(hào)for(j=0;j0);f=1;for(i=0;iMax
Allocation
Need
\n“);for(i=0;i<no1;i++){printf(“p%d/%d“,i,i);for(j=0;j<no2;j++){printf(“%d“,max[i][j]);}for(j=0;j<no2;j++){printf(“%d“,allocation[i][j]);}for(j=0;j<no2;j++){printf(“%d“,ne
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 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ì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度個(gè)人房屋租賃定金協(xié)議及租賃合同終止補(bǔ)償條款2篇
- 2025年廣東高州市鑒龍水務(wù)建設(shè)投資集團(tuán)有限公司招聘筆試參考題庫(kù)附帶答案詳解
- 2025版企業(yè)員工股權(quán)激勵(lì)協(xié)議(限制性股權(quán)實(shí)施)3篇
- 2025年度個(gè)人反擔(dān)保財(cái)產(chǎn)保全執(zhí)行實(shí)施合同
- 2025年全球及中國(guó)雙相抽提修復(fù)系統(tǒng)行業(yè)頭部企業(yè)市場(chǎng)占有率及排名調(diào)研報(bào)告
- 2025年全球及中國(guó)商用卡車(chē)機(jī)電開(kāi)關(guān)行業(yè)頭部企業(yè)市場(chǎng)占有率及排名調(diào)研報(bào)告
- 2025年度二零二五年度高端個(gè)人雇傭員工勞動(dòng)合同標(biāo)準(zhǔn)化范本4篇
- 探索現(xiàn)代青年教育的創(chuàng)新之路
- 2024食品行業(yè)食品安全風(fēng)險(xiǎn)評(píng)估與管控合同模板3篇
- 小學(xué)數(shù)學(xué)教育中的個(gè)性化學(xué)習(xí)與自主學(xué)習(xí)結(jié)合實(shí)踐
- 高考日語(yǔ)基礎(chǔ)歸納總結(jié)與練習(xí)(一輪復(fù)習(xí))
- 《預(yù)防犯罪》課件
- 【企業(yè)作業(yè)成本在上海汽車(chē)集團(tuán)中的應(yīng)用研究案例7300字(論文)】
- 高中物理答題卡模板
- 化學(xué)用語(yǔ)專(zhuān)項(xiàng)訓(xùn)練
- 芳香植物與芳香療法講解課件
- 不孕癥診斷、治療新進(jìn)展課件
- 學(xué)校食堂食品質(zhì)量控制方案
- 天津2021公需課量子信息技術(shù)答案
- 切實(shí)加強(qiáng)領(lǐng)導(dǎo)干部的作風(fēng)建設(shè)課件
評(píng)論
0/150
提交評(píng)論