内存管理详解
1、介绍
内存管理,是指软件运行时对计算机内存资源的分配和使用的技术。其最主要的目的是如何高效,快速的分配,并且在适当的时候释放和回收内存资源。
内存管理的实现方法有很多种,他们其实最终都是要实现 2 个函数: malloc 和 free; malloc 函数用于内存申请, free 函数用于内存释放。
介绍一种简单的实现方法,分块式内存管理:
原理:
malloc分析
首先确定要开辟的内存大小n,从表的最后向前找n个空单元,找到后将其对应的内存地址返回,那么[p,p+n]就是空闲的n个单元。
free函数
free函数不是真的将内存数据清0,而是将其内存管理表清0,表示没有被占用,可以用作开辟内存。
程序理解
//---------------------By xiaowei
/*
头文件,定义了内存池开辟的地址,内存块大小和数目等;
*/
//---------------------
#ifndef _malloc_H
#define _malloc_H
#include "system.h"
#ifndef NULL
#define NULL 0
#endif
//定义2个内存池
#define SRAMIN 0 //内部内存池
#define SRAMEX 1 //外部内存池
#define SRAMBANK 2 //定义支持的SRAM块数.
//mem1内存参数设定.mem1完全处于内部SRAM里面.
#define MEM1_BLOCK_SIZE 32 //内存块大小为32字节
#define MEM1_MAX_SIZE 40*1024 //最大管理内存 40K
#define MEM1_ALLOC_TABLE_SIZE MEM1_MAX_SIZE/MEM1_BLOCK_SIZE //内存表大小,此处为1280,代表有多少块内存;
//mem2内存参数设定.mem2的内存池处于外部SRAM里面
#define MEM2_BLOCK_SIZE 32 //内存块大小为32字节
#define MEM2_MAX_SIZE 960 *1024 //最大管理内存960K
#define MEM2_ALLOC_TABLE_SIZE MEM2_MAX_SIZE/MEM2_BLOCK_SIZE //内存表大小,此处大小30720
//内存管理控制器 函数指针
struct malloc_cortol_struct
{
void (*init)(u8); //初始化,函数入口指针
u8 (*perused)(u8); //内存使用率,带返回值函数入口指针
u8 *membase[SRAMBANK]; //内存池 管理SRAMBANK个区域的内存,是内存池的入口地址
u16 *memmap[SRAMBANK]; //内存管理状态表,内存管理表的地址
u8 memrdy[SRAMBANK]; //内存管理是否就绪
};
extern struct malloc_cortol_struct malloc_cortol; //在mallco.c里面定义
void my_mem_set(void *s,u8 c,u32 num) ; //设置内存
void my_mem_cpy(void *des,void *src,u32 len) ;//复制内存
void my_mem_init(u8 memx); //内存管理初始化函数(外/内部调用)
u32 my_mem_malloc(u8 memx,u32 size); //内存分配(内部调用)
u8 my_mem_free(u8 memx,u32 offset); //内存释放(内部调用)
u8 my_mem_perused(u8 memx); //获得内存使用率(外/内部调用)
////////////////////////////////////////////////////////////////////////////////
//用户调用函数
void myfree(u8 memx,void *paddr) ; //内存释放(外部调用)
void