資料介紹
一、內(nèi)存管理簡介
內(nèi)存管理,是指軟件運(yùn)行時(shí)對計(jì)算機(jī)內(nèi)存資源的分配和使用的技術(shù)。其最主要的目的是如何高效,快速的分配,并且在適當(dāng)?shù)臅r(shí)候釋放和回收內(nèi)存資源。內(nèi)存管理的實(shí)現(xiàn)方法有很多種,他們其實(shí)最終都是要實(shí)現(xiàn) 2 個(gè)函數(shù):malloc 和 free;malloc 函數(shù)用于內(nèi)存申請,free 函數(shù)用于內(nèi)存釋放。本章,我們介紹一種比較簡單的辦法來實(shí)現(xiàn):分塊式內(nèi)存管下面我們介紹一下該方法的實(shí)現(xiàn)原理,如圖
內(nèi)存管理表的項(xiàng)值代表的意義為:當(dāng)該項(xiàng)值為 0 的時(shí)候,代表對應(yīng)的內(nèi)存塊未被占用,當(dāng)該項(xiàng)值非零的時(shí)候,代表該項(xiàng)對應(yīng)的內(nèi)存塊已經(jīng)被占用,其數(shù)值則代表被連續(xù)占用的內(nèi)存塊數(shù)。比如某項(xiàng)值為 10,那么說明包括本項(xiàng)對應(yīng)的內(nèi)存塊在內(nèi),總共分配了 10 個(gè)內(nèi)存塊給外部的某個(gè)指針。內(nèi)寸分配方向如圖所示,是從頂?shù)降椎姆峙浞较颉<词紫葟淖钅┒碎_始找空內(nèi)存。當(dāng)內(nèi)存管理剛初始化的時(shí)候,內(nèi)存表全部清零,表示沒有任何內(nèi)存塊被占用。
二、分配原理
當(dāng)指針 p 調(diào)用 malloc 申請內(nèi)存的時(shí)候,先判斷 p 要分配的內(nèi)存塊數(shù)(m),然后從第 n 項(xiàng)開始,向下查找,直到找到 m 塊連續(xù)的空內(nèi)存塊(即對應(yīng)內(nèi)存管理表項(xiàng)為 0),然后將這 m 個(gè)內(nèi)存管理表項(xiàng)的值都設(shè)置為 m(標(biāo)記被占用),最后,把最后的這個(gè)空內(nèi)存塊的地址返回指針 p,完成一次分配。注意,如果當(dāng)內(nèi)存不夠的時(shí)候(找到最后也沒找到連續(xù)的 m 塊空閑內(nèi)存),則返回 NULL 給 p,表示分配失敗。
三、釋放原理
當(dāng) p 申請的內(nèi)存用完,需要釋放的時(shí)候,調(diào)用 free 函數(shù)實(shí)現(xiàn)。free 函數(shù)先判斷 p 指向的內(nèi)存地址所對應(yīng)的內(nèi)存塊,然后找到對應(yīng)的內(nèi)存管理表項(xiàng)目,得到 p 所占用的內(nèi)存塊數(shù)目 m(內(nèi)存管理表項(xiàng)目的值就是所分配內(nèi)存塊的數(shù)目),將這 m 個(gè)內(nèi)存管理表項(xiàng)目的值都清零,標(biāo)記釋放,完成一次內(nèi)存釋放。
四、部分驅(qū)動(dòng)函數(shù)
//內(nèi)存池(32字節(jié)對齊)
__align(32) u8 mem1base[MEM1_MAX_SIZE]; //內(nèi)部SRAM內(nèi)存池
__align(32) u8 mem2base[MEM2_MAX_SIZE] __attribute__((at(0X68000000)));//外部SRAM內(nèi)存池
//內(nèi)存管理表
u16 mem1mapbase[MEM1_ALLOC_TABLE_SIZE]; //內(nèi)部SRAM內(nèi)存池MAP
u16 mem2mapbase[MEM2_ALLOC_TABLE_SIZE] __attribute__((at(0X68000000 MEM2_MAX_SIZE)));//外部SRAM內(nèi)存池MAP
//內(nèi)存管理參數(shù)
const u32 memtblsize[SRAMBANK]={MEM1_ALLOC_TABLE_SIZE,MEM2_ALLOC_TABLE_SIZE};//內(nèi)存表大小
const u32 memblksize[SRAMBANK]={MEM1_BLOCK_SIZE,MEM2_BLOCK_SIZE};//內(nèi)存分塊大小
const u32 memsize[SRAMBANK]={MEM1_MAX_SIZE,MEM2_MAX_SIZE};//內(nèi)存總大小
//內(nèi)存管理控制器
struct _m_mallco_dev mallco_dev=
{
my_mem_init, //內(nèi)存初始化
my_mem_perused,//內(nèi)存使用率
mem1base,mem2base,//內(nèi)存池
mem1mapbase,mem2mapbase,//內(nèi)存管理狀態(tài)表
0,0, //內(nèi)存管理未就緒
};
//復(fù)制內(nèi)存
//*des:目的地址
//*src:源地址
//n:需要復(fù)制的內(nèi)存長度(字節(jié)為單位)
void mymemcpy(void *des,void *src,u32 n)
{
u8 *xdes=des;
u8 *xsrc=src;
while(n--)*xdes =*xsrc ;
}
//設(shè)置內(nèi)存
//*s:內(nèi)存首地址
//c :要設(shè)置的值
//count:需要設(shè)置的內(nèi)存大小(字節(jié)為單位)
void mymemset(void *s,u8 c,u32 count)
{
u8 *xs = s;
while(count--)*xs =c;
}
//內(nèi)存管理初始化
//memx:所屬內(nèi)存塊
void my_mem_init(u8 memx)
{
mymemset(mallco_dev.memmap[memx], 0,memtblsize[memx]*2);//內(nèi)存狀態(tài)表數(shù)據(jù)清零
mymemset(mallco_dev.membase[memx], 0,memsize[memx]);//內(nèi)存池所有數(shù)據(jù)清零
mallco_dev.memrdy[memx]=1;//內(nèi)存管理初始化OK
}
//獲取內(nèi)存使用率
//memx:所屬內(nèi)存塊
//返回值:使用率(0~100)
u8 my_mem_perused(u8 memx)
{
u32 used=0;
u32 i;
for(i=0;i {
if(mallco_dev.memmap[memx][i])used ;
}
return (used*100)/(memtblsize[memx]);
}
//內(nèi)存分配(內(nèi)部調(diào)用)
//memx:所屬內(nèi)存塊
//size:要分配的內(nèi)存大小(字節(jié))
//返回值:0XFFFFFFFF,代表錯(cuò)誤;其他,內(nèi)存偏移地址
u32 my_mem_malloc(u8 memx,u32 size)
{
signed long offset=0;
u32 nmemb; //需要的內(nèi)存塊數(shù)
u32 cmemb=0;//連續(xù)空內(nèi)存塊數(shù)
u32 i;
if(!mallco_dev.memrdy[memx])mallco_dev.init(memx);//未初始化,先執(zhí)行初始化
if(size==0)return 0XFFFFFFFF;//不需要分配
nmemb=size/memblksize[memx]; //獲取需要分配的連續(xù)內(nèi)存塊數(shù)
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 基于Memcached的緩存資源集中管理方法_郭棟
- 一種基于重疊社區(qū)檢測的TAL管理方法 5次下載
- 總結(jié):維修電路板七種方法資料下載
- STM32F030_LED詳細(xì)配置總結(jié)資料下載
- STM32調(diào)試485(sp3485)技術(shù)總結(jié)資料下載
- STM32總結(jié):NVIC是什么?中斷有多少類型?資料下載
- STM32 經(jīng)驗(yàn)總結(jié),這些你都知道嗎資料下載
- 一種新型閃存緩存管理方法PRLRU 16次下載
- 嵌入式系統(tǒng)教程之嵌入式操作系統(tǒng)的內(nèi)存管理詳細(xì)資料說明 6次下載
- 基于線段樹的內(nèi)存管理方法 2次下載
- 基于對象存儲中的元數(shù)據(jù)組織管理方法 53次下載
- 無線Mesh網(wǎng)絡(luò)位置管理方法 98次下載
- EDA工程建模及其管理方法研究2 0次下載
- 材料技術(shù)管理方法在汽車生產(chǎn)管理中的應(yīng)用
- 網(wǎng)絡(luò)中常用的隊(duì)列管理方法比較
- Linux內(nèi)核內(nèi)存管理架構(gòu)解析 1.8k次閱讀
- Linux內(nèi)存管理體系介紹 2.4k次閱讀
- 使用memheap內(nèi)存管理算法對片內(nèi)RAM和片外SDRAM進(jìn)行管理的方法 4.8k次閱讀
- 單片機(jī)如何對內(nèi)存進(jìn)行管理 1.9w次閱讀
- 智能電能表雙控制器的數(shù)據(jù)管理方法 1.5k次閱讀
- 如何管理Linux 的內(nèi)存分頁? 4.2k次閱讀
- 【新專利介紹】集中抄表系統(tǒng)采集器及電表資產(chǎn)編號搜集管理方法 3.7k次閱讀
- 兩種常見的內(nèi)存管理方法:堆和內(nèi)存池 1.4w次閱讀
- 內(nèi)存管理課程5節(jié)課的總結(jié)說明 3.4w次閱讀
- 一文解析STM32內(nèi)存管理和堆棧的認(rèn)知與理解 1.9w次閱讀
- STM32內(nèi)存管理以及STM32中的堆棧 1.3w次閱讀
- Linux資料匯總之內(nèi)存管理 5.1k次閱讀
- LWIP內(nèi)存管理知識匯總 7.8k次閱讀
- 詳細(xì)圖文剖析STM32單片機(jī)串口一鍵下載電路與操作方法 4.8w次閱讀
- 直流穩(wěn)壓電源制作及管理方法詳解 1.2w次閱讀
下載排行
本周
- 1冷柜-電氣控制系統(tǒng)講解
- 13.68 MB | 4次下載 | 10 積分
- 2安川A1000變頻器中文版說明書
- 20.16 MB | 3次下載 | 3 積分
- 3直流電路的組成和基本定律
- 1.67 MB | 2次下載 | 免費(fèi)
- 4丹佛斯2800系列變頻器說明書
- 8.00 MB | 1次下載 | 5 積分
- 5PC8011同步開關(guān)型降壓3.5A單節(jié)鋰電池充電管理電路技術(shù)手冊
- 0.74 MB | 1次下載 | 免費(fèi)
- 6ES7243E+ES8311音頻錄制與播放電路資料
- 0.06 MB | 1次下載 | 5 積分
- 7SDM02 激光測距模塊產(chǎn)品手冊
- 0.43 MB | 1次下載 | 免費(fèi)
- 8SDFM 激光測距模塊模組手冊
- 0.54 MB | 1次下載 | 免費(fèi)
本月
- 1CH341編程器軟件NeoProgrammer_2.2.0.10
- 20.47 MB | 170次下載 | 1 積分
- 22025智能家居傳感器市場分析及創(chuàng)新應(yīng)用
- 3.11 MB | 43次下載 | 免費(fèi)
- 3RV1126B系列開發(fā)板產(chǎn)品資料
- 4.19 MB | 18次下載 | 免費(fèi)
- 4CH341編程軟件下載
- 2.50 MB | 16次下載 | 5 積分
- 5全志系列-米爾基于T153核心板開發(fā)板 四核異構(gòu)、3路千兆網(wǎng),賦能多元化工業(yè)場景
- 3.05 MB | 12次下載 | 免費(fèi)
- 6【開源】60余套STM32單片機(jī)、嵌入式Linux、物聯(lián)網(wǎng)、人工智能項(xiàng)目案例及入門學(xué)習(xí)資源包
- 10.55 MB | 8次下載 | 免費(fèi)
- 7冷柜-電氣控制系統(tǒng)講解
- 13.68 MB | 4次下載 | 10 積分
- 8特斯拉MODEL S車載充電機(jī)主電路回路原理圖
- 0.81 MB | 4次下載 | 3 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935137次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233094次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191448次下載 | 10 積分
- 5十天學(xué)會AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183356次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81604次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73824次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65991次下載 | 10 積分
電子發(fā)燒友App





創(chuàng)作
發(fā)文章
發(fā)帖
提問
發(fā)資料
發(fā)視頻
上傳資料賺積分
評論