版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 課 程 設(shè) 計</b></p><p><b> 目錄</b></p><p> 蚌埠學(xué)院計算機(jī)科學(xué)與技術(shù)系課程設(shè)計任務(wù)書1</p><p> 計算機(jī)科學(xué)與技術(shù)系課程設(shè)計成績評定標(biāo)準(zhǔn)及成績評定表2</p><p><b> 一、引言3</b
2、></p><p> 1.1 課程設(shè)計的目的3</p><p><b> 1.2實(shí)驗要求3</b></p><p><b> 1.3預(yù)備知識3</b></p><p> 1.4課程設(shè)計內(nèi)容4</p><p><b> 二、需求分析
3、4</b></p><p> 2.1 整體思路4</p><p> 2.2設(shè)計所才用的算法4</p><p> 2.3內(nèi)存分配與回收所使用的結(jié)構(gòu)體5</p><p> 2.4關(guān)于分配留下的內(nèi)存小碎片問題5</p><p> 2.5內(nèi)存的回收5</p><p>&l
4、t;b> 三、總體設(shè)計6</b></p><p> 3.1 數(shù)據(jù)結(jié)構(gòu)描述6</p><p> 3.1.1、全局變量6</p><p> 3.1.2、空閑分區(qū)表定義6</p><p> 3.1.3、已分配表定義6</p><p> 3.1.4、函數(shù)聲明6</p>&
5、lt;p> 3.2 流程圖7</p><p> 3.2.1、系統(tǒng)總體流程圖(如圖3-1所示)7</p><p> 3.2.2作業(yè)分配流程圖8</p><p> 3.2.3內(nèi)存回收流程圖9</p><p><b> 四、詳細(xì)設(shè)計10</b></p><p> 4.1首
6、次適應(yīng)算法10</p><p> 4.2最佳適應(yīng)算法11</p><p> 4.3最差適應(yīng)算法13</p><p> 4.4內(nèi)存回收15</p><p><b> 五、測試運(yùn)行17</b></p><p> 5.1、后臺代碼的截圖17</p><p>
7、 5.1.1 初始化程序,使用首次適應(yīng)、最優(yōu)動態(tài)、最壞適應(yīng)等算法進(jìn)行內(nèi)存分配17</p><p> 5.1.2查看內(nèi)存分配狀態(tài)18</p><p> 5.1.3上下無空閑鄰接回收18</p><p> 5.1.4上鄰接空閑區(qū)回收19</p><p> 5.1.5上下鄰接區(qū)19</p><p><
8、;b> 六、心得體會20</b></p><p><b> 七、參考教材21</b></p><p><b> 附錄:源代碼21</b></p><p> 計算機(jī)科學(xué)與技術(shù)系課程設(shè)計任務(wù)書</p><p> 可變分區(qū)存儲管理方式的內(nèi)存分配回收</p>
9、<p><b> 一、引言</b></p><p> 1.1 課程設(shè)計的目的 </p><p> 本課題采用可變分區(qū)存儲管理方式的模擬實(shí)現(xiàn)內(nèi)存分配與回收。可變分區(qū)分配是一種重要的存儲管理思想,目前流行的操作系統(tǒng)采用的分段存儲管理的基本思想就源自該方法。本課程設(shè)計通過編程模擬可變分區(qū)分配存儲管理,經(jīng)過學(xué)生親自動手編寫管理程序,可以進(jìn)一
10、步加深操作系統(tǒng)中對可變分區(qū)分配存儲管理方案設(shè)計思想的理解。</p><p><b> 1.2實(shí)驗要求</b></p><p> (1) 內(nèi)存分配采用首次適應(yīng)算法、最佳適應(yīng)算法與最差分配算法分別完成。 </p><p> (2) 動態(tài)輸入構(gòu)造空閑區(qū)表,并顯示構(gòu)造好的空閑區(qū)表。(提示:在兩種不同的內(nèi)存分配算法中,空閑區(qū)在空閑區(qū)表中的
11、登記順序是不一樣的)</p><p> (3) 鍵盤接收作業(yè)申請的內(nèi)存尺寸大小。</p><p> (4) 根據(jù)申請,實(shí)施內(nèi)存分配,并返回分配所得內(nèi)存首址。</p><p> (5) 分配完后,調(diào)整空閑區(qū)表(即扣除分配部分),并顯示調(diào)整后的空閑區(qū)表。</p><p> (6) 若分配失敗,返回分配失敗信息。</p>&l
12、t;p> (7) 內(nèi)存回收根據(jù)空閑區(qū)表,按內(nèi)存回收的四種情況從鍵盤接收回收區(qū)域的內(nèi)存首址與大小;回收區(qū)域,調(diào)整空閑區(qū)表(與前面空閑區(qū)相連,與后面空閑區(qū)相連,與前后空閑區(qū)相連則合并,與前后空閑區(qū)都不相連則插入該項),并顯示調(diào)整后的空閑區(qū)表。</p><p><b> 1.3預(yù)備知識</b></p><p> 存儲管理中可變分區(qū)的管理方式,理解掌握作業(yè)申請內(nèi)存
13、時的方法,編程實(shí)現(xiàn)分區(qū)回收算法,對實(shí)驗列出的幾種分區(qū)回收情況都應(yīng)該能處理。熟練運(yùn)用c++編程,采用結(jié)構(gòu)體定義數(shù)組。</p><p><b> 1.4課程設(shè)計內(nèi)容</b></p><p> 編寫程序完成可變分區(qū)存儲管理方式的內(nèi)存分配與回收。</p><p> 具體包括:確定內(nèi)存空間分配表;采用相關(guān)算法完成內(nèi)存空間的分配和回收;撰寫課程設(shè)計報
14、告。</p><p><b> 二、需求分析</b></p><p><b> 2.1 整體思路</b></p><p> 可變分區(qū)管理方式將內(nèi)存除操作系統(tǒng)占用區(qū)域外的空間看做一個大的空閑區(qū)。當(dāng)作業(yè)要求裝入內(nèi)存時,根據(jù)作業(yè)需要內(nèi)存空間的大小 查詢內(nèi)存中的各個空閑區(qū),當(dāng)從內(nèi)存空間中找到一個大于或等于該作業(yè)大小的內(nèi)存空閑
15、區(qū)時,選擇其中一個空閑區(qū),按作業(yè)需求量劃出一個分區(qū)裝人該作業(yè),作業(yè)執(zhí)行完后,其所占的內(nèi)存分區(qū)被收回,成為一個空閑區(qū)。如果該空閑區(qū)的相鄰分區(qū)也是空閑區(qū),則需要將相鄰空閑區(qū)合并成一個空閑區(qū)。</p><p> 2.2設(shè)計所才用的算法</p><p> ?。?)首次適應(yīng)算法,每次為作業(yè)分配內(nèi)存時,總是按當(dāng)前位置下一個位置搜索,查找滿足作業(yè)大小的內(nèi)存給予分配。(2)最優(yōu)適應(yīng)算法,每次為作業(yè)分配內(nèi)
16、存時,總是把既能滿足要求、又是最小的空閑分區(qū)分配給作業(yè)。(3)最差分配算法,每次為作業(yè)分配內(nèi)存時,總是把既能滿足要求、又是最大的空閑分區(qū)分配給作業(yè)。 但最優(yōu)適應(yīng)算法容易出現(xiàn)找到的一個分區(qū)可能只比作業(yè)所需求的長度略大一點(diǎn)的情行,這時,空閑區(qū)分割后剩下的空閑區(qū)就很小以致很難再使用,降低了內(nèi)存的使用率。為解決此問題,設(shè)定一個限值minsize,如果空閑區(qū)的大小減去作業(yè)需求長度得到的值小于等于minsize,不再將空閑區(qū)分成己分分區(qū)和空閑區(qū)兩部
17、分,而是將整個空閑區(qū)都分配給作業(yè)。</p><p> 2.3內(nèi)存分配與回收所使用的結(jié)構(gòu)體</p><p> 為便于對內(nèi)存的分配和回收,建立兩張表記錄內(nèi)存的使用情況。一張為記錄作業(yè)占用分區(qū)的“內(nèi)存分配表”,內(nèi)容包括分區(qū)起始地址、長度、作業(yè)名/標(biāo)志(為0時作為標(biāo)志位表示空欄目);一張為記錄空閑區(qū)的“空閑分區(qū)表”,內(nèi)容包括分區(qū)起始地址、長度、標(biāo)志(0表空欄目,1表未分配)。兩張表都采用順序表
18、形式。</p><p> 2.4關(guān)于分配留下的內(nèi)存小碎片問題</p><p> 當(dāng)要裝入一個作業(yè)時,從“空閑分區(qū)表”中查找標(biāo)志為“1”(未分配)且滿足作業(yè)所需內(nèi)存大小的最小空閑區(qū),若空閑區(qū)的大小與作業(yè)所需大小的差值小于或等于minsize,把該分區(qū)全部分配給作業(yè),并把該空閑區(qū)的標(biāo)志改為“0”(空欄目)。同時,在已分配區(qū)表中找到一個標(biāo)志為“0”的欄目登記新裝人作業(yè)所占用分區(qū)的起始地址,長
19、度和作業(yè)名。若空閑區(qū)的大小與作業(yè)所需大小的差值大于minsize。則把空閑區(qū)分成兩部分,一部分用來裝入作業(yè),另外一部分仍為空閑區(qū)。這時只要修改原空閑區(qū)的長度,且把新裝人的作業(yè)登記到已分配區(qū)表中。</p><p><b> 2.5內(nèi)存的回收</b></p><p> 在可變分區(qū)方式下回收內(nèi)存空間時,先檢查是否有與歸還區(qū)相鄰的空閑區(qū)(上鄰空閑區(qū),下鄰空閑區(qū))。若有,則
20、將它們合件成一個空閑區(qū)。程序?qū)崿F(xiàn)時,首先將要釋放的作業(yè)在“內(nèi)存分配表”中的記錄項的標(biāo)志改為“0”(空欄目),然后檢查“空閑區(qū)表”中標(biāo)志為‘1’(未分配)的欄目,查找是否有相鄰的空閑區(qū),若有,將之合并,并修改空閑區(qū)的起始地址和長度。</p><p><b> 三、總體設(shè)計</b></p><p> 3.1 數(shù)據(jù)結(jié)構(gòu)描述</p><p> 3
21、.1.1 全局變量</p><p> float minsize=5;</p><p> int count1=0;</p><p> int count2=0;</p><p> #define m 10 //假定系統(tǒng)允許的空閑區(qū)表最大為m</p><p> #define n 10 //假定系統(tǒng)允許的最大
22、作業(yè)數(shù)量為m</p><p> 3.1.2 空閑分區(qū)表定義</p><p><b> struct</b></p><p> {float address;//空閑區(qū)起始地址</p><p> float length;//空閑區(qū)長度,單位為字節(jié)</p><p> int fla
23、g; //空閑區(qū)表登記欄標(biāo)志,用"0"表示空欄目,用"1"表示未分配</p><p> }free_table[m]; //空閑區(qū)表 </p><p> 3.1.3 已分配表定義</p><p><b> struct</b></p><p> {float
24、 address; //已分分區(qū)起始地址</p><p> float length; //已分分區(qū)長度,單位為字節(jié)</p><p> int flag; //已分配區(qū)表登記欄標(biāo)志,"0"表示空欄目,實(shí)驗中只支持一個字符的作業(yè)名</p><p> }used_table[n]; //已分配區(qū)表</p><p&g
25、t; 3.1.4 函數(shù)聲明</p><p> void initialize(void);</p><p> int distribute(int,float); //最優(yōu)動態(tài)分配算法</p><p> int shouci(int,float); //首次適應(yīng)算法</p><p> int zuicha(int,flo
26、at); //最差適應(yīng)算法</p><p> int recycle(int); //內(nèi)存回收</p><p> void show(); //顯示狀態(tài)</p><p> void fenpei(); //分配函數(shù)</p><p><b> 3.2 流程圖</b>&l
27、t;/p><p> 3.2.1 系統(tǒng)總體流程圖(如圖3-1所示,以下添加)</p><p> 描述:程序的總體結(jié)構(gòu)方框圖,如下圖3-1所示</p><p> 圖3-1 系統(tǒng)總體流程圖</p><p> 3.2.2 作業(yè)分配流程圖</p><p> 描述:作業(yè)的分配流程圖如圖3-2所示</p>&l
28、t;p> 圖3-2 作業(yè)分配流程圖</p><p> 3.2.3內(nèi)存回收流程圖</p><p> 描述:作業(yè)回收的過程如圖3-3所示</p><p> 圖3-3內(nèi)存回收流程圖</p><p><b> 四、詳細(xì)設(shè)計</b></p><p><b> 4.1首次適應(yīng)算法&
29、lt;/b></p><p> int shouci(int name,float memory){</p><p> int i,k=-1;</p><p> float ads, len;</p><p> int count=0;</p><p><b> i=0;</b>
30、</p><p> while(i<=m-1) //循環(huán)找到最佳的空閑分區(qū)</p><p><b> {</b></p><p> if(memory <=free_table[i].length)</p><p><b> {</b></p><
31、p><b> k=i;</b></p><p><b> break;</b></p><p><b> }</b></p><p><b> i=i+1;</b></p><p><b> }</b></p&
32、gt;<p><b> if(k!=-1)</b></p><p><b> {</b></p><p> if((free_table[k].length-memory)<=minsize) //整個分配</p><p><b> {</b></p>&
33、lt;p> free_table[k].flag=0;</p><p> ads=free_table[k].address;</p><p> len=free_table[k].length;</p><p><b> }</b></p><p><b> else</b><
34、;/p><p><b> {//切割空閑區(qū)</b></p><p> ads=free_table[k].address;</p><p> len=memory;</p><p> free_table[k].address+=memory;</p><p> free_table[k]
35、.length-=memory;</p><p><b> }</b></p><p><b> i=0;</b></p><p> //循環(huán)尋找內(nèi)存分配表中標(biāo)志為空欄目的項</p><p> while(used_table[i].flag!=0) </p><p&
36、gt; {i=i+1;}</p><p> if(i<=n-1) //找到,在已分配區(qū)表中登記一個表項</p><p><b> {</b></p><p> used_table[i].address=ads;</p><p> used_table[i].length=len;<
37、/p><p> used_table[i].flag=name;</p><p><b> count1++;</b></p><p><b> }</b></p><p> else //已分配區(qū)表長度不足</p><p><b> {</
38、b></p><p> if(free_table[k].flag == 0) //將已做的整個分配撤銷</p><p><b> {</b></p><p> free_table[k].flag=1;</p><p> free_table[k].address=ads;</p>&l
39、t;p> free_table[k].length=len;</p><p><b> }</b></p><p> else //將已做的切割分配撤銷</p><p><b> {</b></p><p> free_tabl
40、e[k].address=ads; </p><p> free_table[k].length+=len;</p><p><b> }</b></p><p> cout<<"內(nèi)存分配區(qū)已滿,分配失??!\n"; </p><p><b>
41、return 0;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> cou
42、t <<"無法為該作業(yè)找到合適分區(qū)!\n";</p><p><b> return 0;</b></p><p><b> }</b></p><p> return name;</p><p><b> }</b></p>
43、<p><b> 4.2最佳適應(yīng)算法</b></p><p> //最優(yōu)分配算法實(shí)現(xiàn)的動態(tài)分區(qū)</p><p> int distribute(int process_name, float need_length)</p><p><b> {</b></p><p> i
44、nt i, k=-1;//k用于定位在空閑表中選擇的未分配欄</p><p> float ads, len;</p><p> int count=0;</p><p><b> i=0;</b></p><p> while(i<=m-1) //循環(huán)找到最佳的空閑分區(qū)</p&g
45、t;<p><b> {</b></p><p> if(free_table[i].flag==1 && need_length <=free_table[i].length)</p><p><b> {</b></p><p><b> count++;</
46、b></p><p> if(count==1||free_table[i].length < free_table[k].length)</p><p><b> k=i;</b></p><p><b> }</b></p><p><b> i=i+1;<
47、/b></p><p><b> }</b></p><p><b> if(k!=-1)</b></p><p><b> {</b></p><p> if((free_table[k].length-need_length)<=minsize) //
48、整個分配</p><p><b> {</b></p><p> free_table[k].flag=0;</p><p> ads=free_table[k].address;</p><p> len=free_table[k].length;</p><p><b>
49、 }</b></p><p><b> else</b></p><p><b> {//切割空閑區(qū)</b></p><p> ads=free_table[k].address;</p><p> len=need_length;</p><p>
50、free_table[k].address+=need_length;</p><p> free_table[k].length-=need_length;</p><p><b> }</b></p><p><b> i=0;</b></p><p> //循環(huán)尋找內(nèi)存分配表中標(biāo)志為
51、空欄目的項</p><p> while(used_table[i].flag!=0) </p><p><b> {i=i+1;}</b></p><p> if(i<=n-1) //找到,在已分配區(qū)表中登記一個表項</p><p><b> {</b></p>
52、;<p> used_table[i].address=ads;</p><p> used_table[i].length=len;</p><p> used_table[i].flag=process_name;</p><p><b> count1++;</b></p><p><b
53、> }</b></p><p> else //已分配區(qū)表長度不足</p><p><b> {</b></p><p> if(free_table[k].flag == 0) //將已做的整個分配撤銷</p><p><b> {</b></p&
54、gt;<p> free_table[k].flag=1;</p><p> free_table[k].address=ads;</p><p> free_table[k].length=len;</p><p><b> }</b></p><p> else
55、 //將已做的切割分配撤銷</p><p><b> {</b></p><p> free_table[k].address=ads; </p><p> free_table[k].length+=len;</p><p><b> }</b></p&g
56、t;<p> cout<<"內(nèi)存分配區(qū)已滿,分配失?。n"; </p><p><b> return 0;</b></p><p><b> }</b></p><p><b> }</b></p><p&
57、gt;<b> else</b></p><p><b> {</b></p><p> cout <<"無法為該作業(yè)找到合適分區(qū)!\n";</p><p><b> return 0;</b></p><p><b> }&
58、lt;/b></p><p> return process_name;</p><p><b> }</b></p><p><b> 4.3最差適應(yīng)算法</b></p><p><b> //最差算法實(shí)現(xiàn)</b></p><p> i
59、nt zuicha(int name,float memory){</p><p> int i, k=-1;//k用于定位在空閑表中選擇的未分配欄</p><p> float ads, len;</p><p> int count=0;</p><p><b> i=0;</b></p>
60、<p> while(i<=m-1) //循環(huán)找到最佳的空閑分區(qū)</p><p><b> {</b></p><p> if(free_table[i].flag==1 && memory<=free_table[i].length)</p><p><b> {<
61、/b></p><p><b> count++;</b></p><p> if(count==1||free_table[i].length > free_table[k].length)</p><p><b> k=i;</b></p><p><b> }&l
62、t;/b></p><p><b> i=i+1;</b></p><p><b> }</b></p><p><b> if(k!=-1)</b></p><p><b> {</b></p><p> if
63、((free_table[k].length-memory)<=minsize) //整個分配</p><p><b> {</b></p><p> free_table[k].flag=0;</p><p> ads=free_table[k].address;</p><p> len=free_t
64、able[k].length;</p><p><b> }</b></p><p><b> else</b></p><p><b> {//切割空閑區(qū)</b></p><p> ads=free_table[k].address;</p><
65、p> len=memory;</p><p> free_table[k].address+=memory;</p><p> free_table[k].length-=memory;</p><p><b> }</b></p><p><b> i=0;</b></p&
66、gt;<p> //循環(huán)尋找內(nèi)存分配表中標(biāo)志為空欄目的項</p><p> while(used_table[i].flag!=0) </p><p> {i=i+1;}</p><p> if(i<=n-1) //找到,在已分配區(qū)表中登記一個表項</p><p><b> {</
67、b></p><p> used_table[i].address=ads;</p><p> used_table[i].length=len;</p><p> used_table[i].flag=name;</p><p><b> count1++;</b></p><p>
68、;<b> }</b></p><p> else //已分配區(qū)表長度不足</p><p><b> {</b></p><p> if(free_table[k].flag == 0) //將已做的整個分配撤銷</p><p><b> {</b>&
69、lt;/p><p> free_table[k].flag=1;</p><p> free_table[k].address=ads;</p><p> free_table[k].length=len;</p><p><b> }</b></p><p> else
70、 //將已做的切割分配撤銷</p><p><b> {</b></p><p> free_table[k].address=ads; </p><p> free_table[k].length+=len;</p><p><b> }</b>&l
71、t;/p><p> cout<<"內(nèi)存分配區(qū)已滿,分配失??!\n"; </p><p><b> return 0;</b></p><p><b> }</b></p><p><b> }</b></p>
72、<p><b> else</b></p><p><b> {</b></p><p> cout <<"無法為該作業(yè)找到合適分區(qū)!\n";</p><p><b> return 0;</b></p><p><b&g
73、t; }</b></p><p> return name;</p><p><b> }</b></p><p><b> 4.4內(nèi)存回收</b></p><p><b> //內(nèi)存回收</b></p><p> int rec
74、ycle(int process_name) </p><p><b> {</b></p><p><b> int y=0;</b></p><p> float recycle_address, recycle_length;</p><p> int i, j, k;
75、//j欄是下鄰空閑區(qū),k欄是上欄空閑區(qū)</p><p><b> int x;</b></p><p> //在內(nèi)存分配表中找到要回收的作業(yè)</p><p> while(y<=n-1&&used_table[y].flag!=process_name)</p><p><b>
76、{y=y+1;}</b></p><p> if(y<=n-1) //找到作業(yè)后,將該欄的標(biāo)志置為'0'</p><p><b> { </b></p><p> recycle_address=used_table[y].address;</p><p>
77、recycle_length=used_table[y].length;</p><p> used_table[y].flag=0;</p><p><b> count2++;</b></p><p><b> }</b></p><p> else //未能找到
78、作業(yè),回收失敗</p><p><b> {</b></p><p> cout<<"該作業(yè)不存在!\n";</p><p><b> return 0;</b></p><p><b> }</b></p><p&g
79、t;<b> j=k=-1;</b></p><p><b> i=0;</b></p><p> while(!(i>=m||(k!=-1&&j!=-1))) //修改空閑分區(qū)表</p><p><b> {</b></p><p>
80、 if(free_table[i].flag==1)</p><p> {if((free_table[i].address+free_table[i].length)==recycle_address)</p><p> k=i;//判斷是否有上鄰接</p><p> if((recycle_address+recycle_length)==fre
81、e_table[i].address)</p><p> j=i;//判斷是否有下鄰接</p><p><b> }</b></p><p><b> i=i+1;</b></p><p><b> }</b></p><p><b&
82、gt; //合并空閑區(qū)</b></p><p> if(k!=-1) //回收區(qū)有上鄰接</p><p><b> {</b></p><p> if(j!=-1){//回收區(qū)也有下鄰接,和上下領(lǐng)接合并</p><p> free_table[k].length+=free_ta
83、ble[j].length+recycle_length;</p><p> free_table[j].flag=0;//將第j欄的標(biāo)記置為'0'</p><p><b> }</b></p><p> else //不存在下鄰接,和上鄰接合并</p><p&
84、gt; free_table[k].length+=recycle_length;</p><p><b> }</b></p><p> else if(j!=-1)</p><p> { //只有下鄰接,和下鄰接合并</p><p> free_tabl
85、e[j].length+=recycle_length;</p><p> free_table[j].address=recycle_address;</p><p><b> }</b></p><p><b> else </b></p><p> {
86、 //上下鄰接都沒有</p><p><b> x=0;</b></p><p> while(free_table[x].flag!=0)</p><p> x=x+1;//在空閑區(qū)表中查找一個狀態(tài)為'0'的欄目</p><p> if(x<=m-1)</p>
87、;<p> { //找到后,在空閑分區(qū)中登記回收的內(nèi)存</p><p> free_table[x].address=recycle_address;</p><p> free_table[x].length=recycle_length;</p><p> free_table[x].flag=1;</p>
88、<p><b> }</b></p><p><b> else</b></p><p> { //空閑表已滿,執(zhí)行回收失敗</p><p> used_table[y].flag=process_name;</p><p&g
89、t; cout<<"空閑區(qū)已滿,回收失敗!\n";</p><p><b> return 0;</b></p><p><b> }</b></p><p><b> }</b></p><p> return process_nam
90、e;</p><p><b> }</b></p><p><b> 五、測試運(yùn)行</b></p><p> 5.1、后臺代碼的截圖</p><p> 5.1.1 初始化程序 </p><p> ?。?)如圖5-1所示,系統(tǒng)采用首次適應(yīng)、最佳、最差適應(yīng)算法進(jìn)行內(nèi)存分配
91、(格式)</p><p><b> 圖5-1 分配內(nèi)存</b></p><p> 5.1.2查看內(nèi)存分配狀態(tài)</p><p> ?。?)如圖5-2所示,內(nèi)存分配狀態(tài)顯示</p><p><b> 圖5-2顯示狀態(tài)</b></p><p> 5.1.3上下無空閑鄰接回收
92、</p><p> ?。?)如圖5-3所示,回收單一分配空間</p><p><b> 圖5-3無鄰接回收</b></p><p> 5.1.4上鄰接空閑區(qū)回收</p><p> ?。?)如圖5-4所示,回收區(qū)和上鄰接區(qū)合并</p><p><b> 圖5-4上鄰接</b&g
93、t;</p><p> 5.1.5上下鄰接區(qū)</p><p> (5)如圖5-4所示,回收區(qū)和上下鄰接區(qū)合并</p><p><b> 圖5-5上下鄰接</b></p><p><b> 六、心得體會</b></p><p> 設(shè)計本課程前,感覺本課程并不是那么難,
94、很容易下手,因為主要也就是寫出回收主程序、內(nèi)存分配主程序就行了。但是真正實(shí)施起來確非常困難。 </p><p> 首先,必須解決動態(tài)輸入構(gòu)造空閑區(qū)表的問題。剛開始的時候,我們把其他的程序都寫出來了,卻忘了課題還要求動態(tài)輸入構(gòu)造空閑區(qū)表。于是我們又花了很大的力氣才實(shí)現(xiàn)動態(tài)輸入構(gòu)造空閑區(qū)表,即:可以根據(jù)自己的需要,從鍵盤輸入空閑區(qū)表的塊數(shù),并輸入每塊空閑區(qū)表的大小及首地址。 </p>
95、<p> 其次,需要解決的是首次適應(yīng)算法和最佳適應(yīng)算法之間的轉(zhuǎn)制問題。我們做完首次適應(yīng)算法的程序后不知道該從什么地方著手寫最佳適應(yīng)算法。最后過了幾天,才想到,原來只需在首次適應(yīng)算法中,每次申請空閑區(qū)前先對空閑區(qū)從小到大排序即可。第三個難題就是解決回收算法的問題。回收算法可以說是本實(shí)驗最難實(shí)現(xiàn)的算法,因為它有四種不同的情況。剛開始我們只考慮了三種情況,即:</p><p> 1、要回收的區(qū)域沒有與
96、之相鄰接的空閑區(qū)。 </p><p> 2、要回收區(qū)域有上鄰(與要回收區(qū)域相鄰的上面有空閑區(qū))。 </p><p> 3、要回收的區(qū)域有下鄰(與要回收的區(qū)域相鄰的下面有空閑區(qū))。 </p><p> 當(dāng)我們滿懷欣喜感覺本課程設(shè)計已經(jīng)完成的時候卻發(fā)現(xiàn),程序運(yùn)行的時候,對于一個剛分配好的空閑區(qū),如果有三個相鄰的作業(yè)可以同時在此空閑區(qū)內(nèi)
97、申請到內(nèi)存,并全并回收此三個作業(yè)后,此空閑區(qū)會被分割成兩個空閑區(qū)顯示。這時我們才意識到少考慮了一種情況:要回收的區(qū)域有上鄰而且有下鄰。我們又不得不再次修改程序。 就這樣,在寫出大體程序后,我們前后大大小小修改了十多次,最后修改好的程序完全符合課程設(shè)計要求,我們的課程設(shè)計終于成功了!</p><p><b> 七、參考教材</b></p><p> 1.
98、湯小丹.計算機(jī)操作系統(tǒng),西安電子科技大學(xué)出版社.2014</p><p> 2.譚浩強(qiáng).C++程序設(shè)計.清華大學(xué)出版社.2004</p><p> 3.郭有強(qiáng)等編著.《C++面向?qū)ο蟪绦蛟O(shè)計》.2009</p><p> 4.郭有強(qiáng)等編著.《C++面向?qū)ο蟪绦蛟O(shè)計實(shí)驗指導(dǎo)與課程設(shè)計》.2009</p><p><b> 附錄
99、:源代碼</b></p><p> #include<iostream></p><p> #include<iomanip></p><p> #include<string></p><p> using namespace std;</p><p><
100、b> //全局變量</b></p><p> float minsize=5;</p><p> int count1=0;</p><p> int count2=0;</p><p> #define m 10 //假定系統(tǒng)允許的空閑區(qū)表最大為m</p><p> #define n
101、10 //假定系統(tǒng)允許的最大作業(yè)數(shù)量為m</p><p><b> //已分配表的定義</b></p><p><b> struct {</b></p><p> float address; //已分分區(qū)起始地址</p><p> float length; //已分分區(qū)長度,單位
102、為字節(jié)</p><p> int flag; //已分配區(qū)表登記欄標(biāo)志,"0"表示空欄目</p><p> }used_table[n]; //已分配區(qū)表的對象名</p><p><b> //空閑區(qū)表的定義</b></p><p><b> struct{</b
103、></p><p> float address; //空閑區(qū)起始地址</p><p> float length; //空閑區(qū)長度,單位為字節(jié)</p><p> int flag; //空閑區(qū)表登記欄標(biāo)志,用"0"表示空欄目,用"1"表示未分配</p><p> }fr
104、ee_table[m]; //空閑區(qū)表對象名</p><p><b> //函數(shù)聲明</b></p><p> void initialize(void);</p><p> int distribute(int,float); //最優(yōu)動態(tài)分配算法</p><p> int shouci(int,float
105、); //首次適應(yīng)算法</p><p> int zuicha(int,float); //最差適應(yīng)算法</p><p> int recycle(int); //內(nèi)存回收</p><p> void show(); //顯示狀態(tài)</p><p> void fenpei(); //
106、分配函數(shù)</p><p><b> //主函數(shù)</b></p><p> void main(){</p><p> //system("color 09"); /*修改控制臺的顏色信息,改為白字藍(lán)底的模式*/ </p><p> system("mode con: cols=14
107、0 lines=130"); /*設(shè)置批處理運(yùn)行時窗口大小的*/ </p><p> int choice;</p><p> bool exitFlag=false;</p><p> cout<<"\t\t\t 動態(tài)分區(qū)分配方式的模擬 \n";</p><p>
108、cout<<"\t\t\t ************************************\n";</p><p> cout<<"請選擇操作類型:\n";</p><p> initialize(); //開創(chuàng)空閑區(qū)和已分配區(qū)兩個表</p><p> while(!exitFlag
109、)</p><p><b> {</b></p><p> cout<<"\t\t\t********************************************\n";</p><p> cout<<"\t\t\t** 1: 分配內(nèi)存 2: 回收內(nèi)存
110、 **\n";</p><p> cout<<"\t\t\t** 3: 查看分配 0: 退 出 **\n";</p><p> cout<<"\t\t\t********************************************\n";</p>
111、<p> cout<<"請輸入您的操作 :";</p><p> cin >>choice;</p><p> switch(choice){</p><p><b> case 0:</b></p><p> exitFlag=true;</p&
112、gt;<p><b> break;</b></p><p><b> case 1:</b></p><p> fenpei(); //分配內(nèi)存</p><p><b> break;</b></p><p><b> case 2:<
113、/b></p><p><b> int ID;</b></p><p> cout<<"請輸入你要釋放的分區(qū)號:";</p><p><b> cin>>ID;</b></p><p> recycle(ID);</p>&l
114、t;p><b> break;</b></p><p><b> case 3:</b></p><p><b> show();</b></p><p><b> break;</b></p><p><b> }</b&
115、gt;</p><p><b> }</b></p><p><b> }</b></p><p><b> //初始化兩個表</b></p><p> void initialize(void){</p><p><b> int
116、a;</b></p><p> for(a=0;a<=n-1;a++){</p><p> used_table[a].flag=0; //已分配表的表項全部置為空表項</p><p> free_table[0].address=1000;</p><p> free_table[0].length=1024;&
117、lt;/p><p> free_table[0].flag=1; //空閑區(qū)表的表項全部為未分配</p><p><b> }</b></p><p><b> }</b></p><p><b> //分配表</b></p><p> void
118、 fenpei(){</p><p> int job_name;</p><p> float need_memory;</p><p> bool exitFlag=false;</p><p> int choice;</p><p> while(!exitFlag){</p><
119、p> cout<<"\t\t\t*****************************************************\n";</p><p> cout<<"\t\t\t** 1: 首次適應(yīng)算法 2: 最優(yōu)動態(tài)分配算法 **\n";</p><p> cout<&
120、lt;"\t\t\t** 3: 最壞適應(yīng)算法 4: 返回主菜單 **\n";</p><p> cout<<"\t\t\t*****************************************************\n";</p><p> cout<<"請輸入您
121、的操作 :";</p><p> cin>>choice;</p><p> switch(choice){</p><p><b> case 1:</b></p><p> cout<<"請輸入作業(yè)名和所需內(nèi)存:";</p><p>
122、; cin>>job_name>>need_memory;</p><p> shouci(job_name,need_memory);</p><p><b> break;</b></p><p><b> case 2:</b></p><p> cout&l
123、t;<"請輸入作業(yè)名和所需內(nèi)存:";</p><p> cin>>job_name>>need_memory;</p><p> distribute(job_name,need_memory);</p><p><b> break;</b></p><p>&l
124、t;b> case 3:</b></p><p> cout<<"請輸入作業(yè)名和所需內(nèi)存:";</p><p> cin>>job_name>>need_memory;</p><p> zuicha(job_name,need_memory);</p><p>
125、;<b> break;</b></p><p><b> case 4:</b></p><p> exitFlag=true;</p><p><b> }</b></p><p><b> }</b></p><p>
126、;<b> }</b></p><p><b> //首次適應(yīng)算法</b></p><p> int shouci(int name,float memory){</p><p> int i,k=-1;</p><p> float ads, len;</p><p
127、> int count=0;</p><p><b> i=0;</b></p><p> while(i<=m-1) //循環(huán)找到最佳的空閑分區(qū)</p><p><b> {</b></p><p> if(memory <=free_table[i].le
128、ngth)</p><p><b> {</b></p><p><b> k=i;</b></p><p><b> break;</b></p><p><b> }</b></p><p><b> i=i
129、+1;</b></p><p><b> }</b></p><p><b> if(k!=-1)</b></p><p><b> {</b></p><p> if((free_table[k].length-memory)<=minsize)
130、 //整個分配</p><p><b> {</b></p><p> free_table[k].flag=0;</p><p> ads=free_table[k].address;</p><p> len=free_table[k].length;</p><p><b&g
131、t; }</b></p><p><b> else</b></p><p><b> {//切割空閑區(qū)</b></p><p> ads=free_table[k].address;</p><p> len=memory;</p><p> fr
132、ee_table[k].address+=memory;</p><p> free_table[k].length-=memory;</p><p><b> }</b></p><p><b> i=0;</b></p><p> //循環(huán)尋找內(nèi)存分配表中標(biāo)志為空欄目的項</p
133、><p> while(used_table[i].flag!=0) </p><p> {i=i+1;}</p><p> if(i<=n-1) //找到,在已分配區(qū)表中登記一個表項</p><p><b> {</b></p><p> used_table[i].
134、address=ads;</p><p> used_table[i].length=len;</p><p> used_table[i].flag=name;</p><p><b> count1++;</b></p><p><b> }</b></p><p&g
135、t; else //已分配區(qū)表長度不足</p><p><b> {</b></p><p> if(free_table[k].flag == 0) //將已做的整個分配撤銷</p><p><b> {</b></p><p> free_table[k].flag=1
136、;</p><p> free_table[k].address=ads;</p><p> free_table[k].length=len;</p><p><b> }</b></p><p> else //將已做的切割分配撤銷</p>
137、<p><b> {</b></p><p> free_table[k].address=ads; </p><p> free_table[k].length+=len;</p><p><b> }</b></p><p> cout<<"
138、內(nèi)存分配區(qū)已滿,分配失敗!\n"; </p><p><b> return 0;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> else</b></
139、p><p><b> {</b></p><p> cout <<"無法為該作業(yè)找到合適分區(qū)!\n";</p><p><b> return 0;</b></p><p><b> }</b></p><p> r
140、eturn name;</p><p><b> }</b></p><p> //最優(yōu)分配算法實(shí)現(xiàn)的動態(tài)分區(qū)</p><p> int distribute(int process_name, float need_length)</p><p><b> {</b></p>
141、<p> int i, k=-1;//k用于定位在空閑表中選擇的未分配欄</p><p> float ads, len;</p><p> int count=0;</p><p><b> i=0;</b></p><p> while(i<=m-1) //循環(huán)找到最佳
142、的空閑分區(qū)</p><p><b> {</b></p><p> if(free_table[i].flag==1 && need_length <=free_table[i].length)</p><p><b> {</b></p><p><b>
溫馨提示
- 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)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 課程設(shè)計報告-可變分區(qū)存儲管理
- 操作系統(tǒng)課程設(shè)計--模擬實(shí)現(xiàn)可變分區(qū)存儲管理
- 操作系統(tǒng)原理課程設(shè)計報告-可變分區(qū)存儲管理
- 存儲器動態(tài)分區(qū)算法模擬課程設(shè)計報告
- c語言課程設(shè)計_存儲管理分區(qū)分配算法
- 【linux課程設(shè)計】可變分區(qū)最佳適應(yīng)算法源代碼
- 模擬實(shí)現(xiàn)一個簡單的固定(可變)分區(qū)存儲管理系統(tǒng)
- 操作系統(tǒng)課程設(shè)計---動態(tài)分區(qū)分配存儲管理
- 可變分區(qū)首次適應(yīng)算法
- 實(shí)驗 可變分區(qū)內(nèi)存分配首次適應(yīng)算法模擬
- 模擬頁式存儲管理-操作系統(tǒng)課程設(shè)計
- 模擬頁式存儲管理 操作系統(tǒng)課程設(shè)計
- 基本分頁存儲管理的模擬實(shí)現(xiàn) 課程設(shè)計
- 課程設(shè)計--請求調(diào)頁存儲管理方式的模擬
- 模擬頁式存儲管理-操作系統(tǒng)課程設(shè)計報告
- 《操作系統(tǒng)》課程設(shè)計---連續(xù)動態(tài)分區(qū)內(nèi)存管理模擬實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計--連續(xù)動態(tài)分區(qū)內(nèi)存管理模擬實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計--連續(xù)動態(tài)分區(qū)內(nèi)存管理模擬實(shí)現(xiàn)
- 課程設(shè)計---存儲器管理系統(tǒng)設(shè)計
- 操作系統(tǒng)課程設(shè)計--模擬請求頁式存儲管理
評論
0/150
提交評論