版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領
文檔簡介
計設和現(xiàn)個支持多程存分配釋放的動存管系統(tǒng)(Multi-threadedDynamicMemory之后稱MTDMM)該系統(tǒng)為多線程應用程序的內(nèi)使用和管理提供有效的解決方案對多程的線程共享和線程有數(shù)據(jù)提供不同存儲策根需通動存管理統(tǒng)出內(nèi)存分配或釋放的請求存儲管理系統(tǒng)根請求在不同的存儲空間中完成具體的操作對線共的內(nèi)存分或放求在線程共享的存儲空間中操而對于線程私的內(nèi)存分配或釋放請,則在該線程對的私有存儲空間中操。該系統(tǒng)可向用提供以下兩大功多個程供個共享的儲間線程間的數(shù)據(jù)共享和據(jù)通信每線建立個有存儲空間足程私有數(shù)據(jù)分和釋。儲理對接接口動態(tài)儲管系以下簡稱供下外接口供用戶用以完對程共享線程私有的動態(tài)存儲單元的分配與釋放int初化系每使MTDMM的序只應當使用一次成功執(zhí)行則返0,否則返回誤碼
int終MTDMM統(tǒng)對于每個用MTDMM的若成功執(zhí)行則回否則回代。intmm_createspace(pthread_tpth_id)新始線創(chuàng)建程私空間,參為相線程線程。成返回,則回誤代碼int線程結(jié)束前釋放線程私有空間若成功執(zhí)行則返,否則回錯誤代碼。mm_alloc(pthread_tpth_id,intsize)線程私有動態(tài)內(nèi)分配函數(shù),參數(shù)是線程,size是申請大小,以字節(jié)為位若分配成功則返回分得空間的首址,類型為void*,否回。intmm_free(pthread_tpth_id,ptr)線程私有動態(tài)內(nèi)存釋放函數(shù)參數(shù)tid是線程線程號ptr為待放內(nèi)存址通常為指針變量。若成功執(zhí)行則返回0,則回誤代碼MM(memorymanager)3.1MMIndex_list
地址01517
space*space*space*space*
publicspaceNULL
blobloblockckckblblobloocckckk
NULL、
、、、#+1
、、space*
NULL
圖動態(tài)存儲管理結(jié)構(gòu)的主要數(shù)據(jù)構(gòu)組織MM主數(shù)據(jù)結(jié)構(gòu)如1示。在MM化將待的空將分部個長間表空初空空池初定義數(shù)目)在MM初始還為線程共享數(shù)據(jù)創(chuàng)建1個公存儲(blic),并將這個注到間引中每個初掛載定義個。當MM第1次收到某線程(非主程)的動態(tài)內(nèi)存配請求,將為該程創(chuàng)建一個對應私有儲并默認載個block后注冊到引中為線的有間當MM到pth_id)請時,會將該線程pth_id對的space放入空閑空間池中,同時釋放space掛載的所到空閑儲塊池中MM結(jié)以上的敘述,定MM下word_mm{//索引表struct
,//b
structword_space_head*
,//有當息pthread_mutex_t////pthread_mutex_t//索引表//}word_mm,義宏定義是為了讓用戶實現(xiàn)自定大小,數(shù)量等信息,這里的數(shù)據(jù)是初始化時的默認值:30//
spaceBLCOK_NUM100//
在池的目
義的展池block目//義是組織block部的SECTOR_SIZE128//定義的sector的單位節(jié)3//
的block目MM_HASH_FUC(tid)//HASH義索引表簡介索引表的容納式是采鏈式hash法它的作用管理所正在使用的根據(jù)定的程編號pth_id可以快速的在索表中查找到該線程對應nit,向相應的;然在這個space上完成線程的內(nèi)存分配與釋放請。索引表中含有下列tid和個指針該指指某用的頭部個用指下一個nit單元。索引的結(jié)構(gòu)tid0*1*43*-1*2*-1*......
NULLNULL圖索引的結(jié)構(gòu)圖示了運行過程中的索引結(jié)構(gòu)中一索項是共space對的索引項,這塊在MM初化的時候建立,在MM銷毀時候銷當毀1個space時,需刪除該space在索引表中對應索引項引采Hash實處沖突的法用地法,由于三作,圖沒顯出這關(guān)系。索引表的定義根據(jù)上面的敘述定于索引表中的素如下:index_list_unit{unsignedlong//
該space*space;的塊用于多block*nextUnit//hash}index_list_unit,list_unit_t;_unit_tlist_index[LIST_LENGTH]在結(jié)構(gòu)體中定義的是一個行項結(jié)構(gòu)體的數(shù)組4.3
intmm_list_init()初始創(chuàng)索表本的是得頭的list數(shù)實體化。初化時調(diào)用此數(shù),創(chuàng)建成功回0。intmm_list_logon(utid)線程第一次申請內(nèi)存時候或顯示調(diào)用創(chuàng)space候注索引;參數(shù)tid是編號。該函數(shù)用get函數(shù)獲頭和的block塊動,之冊表返。intlongtid)線程結(jié)束之后,在索引表中注將tid記刷-1用space頭入池調(diào)rn將block塊還池longtid)據(jù)tid參定返型。函只是一個能數(shù)為其函使。5.1空閑空間池中由若干個空閑成這都有一個頭信息,大小零標未用。在注索表標記已用脫池。銷之后仍然回到該池,池的作相當于是空閑的管理池。5.2Space數(shù)
空總閑數(shù)數(shù)
空總閑數(shù)數(shù)斥鎖
圖space空閑空間的組織結(jié)構(gòu)如圖所示,中的space都指向任何block,有要標信。5.3Space義
Space池頭結(jié)信息下:structstructword_space*firstSpace;//
個//
錄space的pthread_mutex_t//Space
互斥鎖
//用實現(xiàn)對pace空}word_space_head,space_head_t;結(jié)點結(jié)構(gòu)如下:inttSize;//記錄space塊掛總存空大小(以數(shù)示intfSize;//錄space所載的空閑內(nèi)存大以塊數(shù)示structword_block//指一個block塊word_space*sNext;//指一塊Space接
int立space鏈頭鏈函得結(jié)中的實體化。創(chuàng)一個空載的頭返回指針型。在有新線程建立且space池無閑space頭時用函,回針交給引,成冊()響應程新立求該數(shù)優(yōu)搜空池否有有返回,如果沒有調(diào)上面的函數(shù)生成一個新的;返回指向獲得的的指針intmm_space_return(space*ptr)響線程結(jié)束的注函數(shù),參數(shù)ptr指線對應的將此塊space頭入池中。果注銷成功返回0;函數(shù)還要修改鏈頭的信息blocks6.1該池中單元block是初始化MM時候由用戶定大小單的最小儲元建的個數(shù)也被用戶指定。被space使管,身于己的內(nèi)存有套理式head包含一基本關(guān)block信息,如鎖互斥剩block數(shù)等。數(shù)blcok數(shù)blockblockblock
Spacepointer圖block池的據(jù)結(jié)構(gòu)組織圖是運行過程中某一刻的態(tài),色表示已占而色的表示閑space中的指指向一個同個space的block會相互連。head引的線示是將有的閑的塊連,這做目的方便找空的塊。對block內(nèi)的構(gòu)以它部管理的方式,將第七節(jié)論
block池頭點如:block*//指
tSize;//記fSize;//記block
池中數(shù)塊
structword_block*ffBlock;//記錄第一pthread_mutex_t斥鎖對pace的制
fnum:k
block內(nèi)部的數(shù)據(jù)構(gòu)如右圖示,結(jié)結(jié)下
tsNum;//shortfsNum;//
該小小
//置structword_block*//向池鏈中一blockstructword_block*
//被space塊中的//下一個//在被占時指下一空閑block}word_block,block;其中sector的組
intmm_block_chead()建池函數(shù)使得結(jié)構(gòu)體mm的mm_block_head實體block*創(chuàng)建個block塊返型;初化。block*mm_block_reblock()應space的加動,找中第個有占的block塊,回block*并且修改池信息。該函數(shù)用來展space塊大小。bool*mm_block_return(block響還塊動作,參數(shù)是該的塊;該函數(shù)線程注銷時候由引表函調(diào),旦行,需要改針修改block池的鏈頭。intmm_block_realloc()在池中的有塊已經(jīng)被用是仍然有新的線程建立block池本身私下里用此數(shù)次拓展申請辟BLOCK_RENUM個塊Space7.1-sectorSector是的分配用,用于戶儲使用內(nèi)最小單Sector按照一定量(取決宏)被組織在個block塊中。它的小也是取于宏頭SECTOR_SIZE,單位字節(jié)。其中,前兩個字節(jié)在初始化的時候被制定,存放個r指于組織在block中(相于靜鏈表),而在被分配出去后被用戶寫覆蓋在線space對于的理對的理對于線程戶辟釋放間的內(nèi)部現(xiàn)在space配算法指的是對于用戶的局部申請有著最為實際和有效的內(nèi)分配算法,這個算可以改進;本次我們的算總體思是頭block為節(jié)點創(chuàng)s鏈以為位由block用態(tài)方組空閑sector,響應戶的局部申請。curcur
space
blockblocktsizefsizesnext
bnext
bnext
sb_next
block
圖在線space的一時狀面表一:所域稱型稱spacefblockblock*block
用途指第一個掛載在上的block部shortshort
短型數(shù)大短型空閑數(shù),最大space*nextspacets_numshorttotal
注后接入space池,用于串在鏈上記錄掛在本block上的sector總數(shù)頭部
fs_numshortfreefnumshortblock*nextblocksb_nextblock*
記錄掛在本block上的sector空數(shù)記第一個空閑的號當靜鏈鏈頭在池中續(xù)block創(chuàng)成bh鏈指下一個掛載在上的block果本block占指向鏈中下一個用----------------------block中的小分配單元,邏件curshort
短型表的對于載的構(gòu)建以用函數(shù)(參見接口),構(gòu)建完成后,可注冊再掛載,是容易的對初始化block即用mm_block_init數(shù)實現(xiàn)制是先從存中得一大小字節(jié)的間它表示頭大,加上后面所的單元大返回的指針強制block*,始入充block頭,地址是BYTE*p=(BYTE*)nodeBlock;所的址第個的采用強的方式這個cur值地,寫入。7.4分配算法7.4.1流圖我們展示了用戶的一次申請中實現(xiàn)的流程用Alloc(tidsize)
Locate(tid)
次?
是否logon(tid)Void*指針分法
reblock
是否
圖用戶內(nèi)存申請流程其中使到的函數(shù)都是上面的組件中所定過的函數(shù)些函實制意事項都函數(shù)介紹中說。下面的工作就是來詳細的解釋下圖6中分法7.4.2block分算法圖說block在分前經(jīng)保了本中足的間分配即block不發(fā)生溢的錯誤分配結(jié)后block(有大存的的返給用戶分配束參看圖到之后從鏈向后查找到第個block塊的fsNum>1(表還有sector可給分配)進行塊的分配到一個的sector,下地的cur值寫fNum頭頭空數(shù)進行有,是個字,是SECTOR_SIZE-2個,有個字節(jié)是給了?不錯,在空的,cur值個節(jié)了個一分配,這個cur值有意義,可(實上是為值,用戶拿到這個塊后寫入其數(shù)了)space釋算法釋算法的流程圖在,為看了,就以。有個參數(shù)個tid用在表中定位在有直返回;還有void*,是是的空的地。采頭法行入,定到的后鏈地址的法找到塊block指的頭個字節(jié)short*型且寫入fnum的值將m改當回sector塊的索引號,這就是頭插法還回sector。下使用況分析臨界分及選定的鎖系統(tǒng)的結(jié)以三層引(space層(對、block在線使時免不對這些線性結(jié)構(gòu)進行search等以這結(jié)構(gòu)就是臨界資源且些界源作整存的也是說,單獨的nit或或是block都不成為臨界資源的,只有它們在對應的線性結(jié)構(gòu)上才成為臨界資源一部分另外,(即共享區(qū))由一indexnit個及個block構(gòu),由于為所有線程共享,所其整體也為臨界資源。對臨界資源,為了防止多線程操作時出現(xiàn)問題,必須對其進行同步、互斥處理,系采用加鎖方來實現(xiàn)互斥方考到臨資源任單獨的單元構(gòu)成界一方面考慮小粒度會帶來更大的空時間開銷以及更容易帶來死所以每個臨資源整加鎖即鎖量——block池來定block池shLock——池鎖(來鎖定spaceindex—index鎖(用來鎖定索引表);——共享區(qū)來鎖定共享區(qū)種分別設定block池結(jié)構(gòu)和池頭結(jié)中,后兩種設在結(jié)中各數(shù)定關(guān)系首,為了方便與安全,所有函數(shù)如需加鎖,則該函數(shù)保持運行全程不解鎖,只在數(shù)將運結(jié)束時再解鎖以下述只描述單層函數(shù)若函數(shù)調(diào)用函數(shù)加鎖況予描)于始化數(shù)運行在序最開始,所在同時不有線程運情發(fā)生,便不用執(zhí)行任何加鎖操作,只將有初化可塊space塊建一,所以用加鎖mm_block_reblock數(shù)需從block-pool上查并取塊要bhLock鎖。數(shù)由于需要將插block-pool,以將bhLock鎖。mm_block_realloc函于需內(nèi)存間做成block插入以展,以需要鎖。但是該函數(shù)只被reblock調(diào),不上。、mm_list_logoff、數(shù)由于要上找,以需將indexlock鎖上函數(shù)于需要在中檢索所以需要上rn函需要將插所需將shLock鎖。mm_allocmm_free在參數(shù)tid要對共享區(qū)進行操作以需將鎖上。以是所有鎖會在何時被鎖上及解開。各函數(shù)深層對鎖的操作可以由以上描述和之的函數(shù)用關(guān)系圖來推。MTDMM代碼結(jié)文件函分布關(guān)、MTDMM系統(tǒng)的結(jié)
MTDMM文件構(gòu)
()圖統(tǒng)的文結(jié)構(gòu)圖是系統(tǒng)的致可分三個層:底層操層部控制、對外接層其中層操層直接面向內(nèi)的block操作,下:block池頭的立block池的初化block的取塊block的還塊block池的展
int(intblock*mm_block_reblock()block*rn(block*
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 公共衛(wèi)生間裝修施工合同范本
- 建筑垃圾運輸司機招聘合同
- 文化傳媒會計勞動合同
- 化工原料采購招投標合同條款
- 2024版樹苗供應合同
- 公司入?yún)f(xié)議書范本
- 二零二五年度生態(tài)農(nóng)業(yè)PPP模式合作合同
- 2024物聯(lián)網(wǎng)智能硬件產(chǎn)品研發(fā)與生產(chǎn)合同
- 2024版行政單位炊事工作人員勞動協(xié)議版
- 二零二五年度海底電纜安裝工程海洋生物災害保險協(xié)議2篇
- 商業(yè)銀行風險偏好和限額管理管理辦法
- 《數(shù)學課程論》課件
- 2024年國家公安部直屬事業(yè)單位招錄人民警察及工作人員696人筆試(高頻重點復習提升訓練)共500題附帶答案詳解
- 初中必背古詩文138首
- 車站調(diào)度員(技師)技能鑒定理論考試題庫(含答案)
- 2024年房屋交接確認書
- 【深信服】PT1-AF認證考試復習題庫(含答案)
- 反芻動物消化道排泄物原蟲診斷技術(shù)規(guī)范
- 開放系統(tǒng)10861《理工英語(4)》期末機考真題及答案(第102套)
- 2024年國家能源集團招聘筆試參考題庫含答案解析
- GB/T 43824-2024村鎮(zhèn)供水工程技術(shù)規(guī)范
評論
0/150
提交評論