找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1564|回复: 0
打印 上一主题 下一主题
收起左侧

内存的malloc和free结构体

[复制链接]
跳转到指定楼层
楼主
ID:105323 发表于 2016-2-23 23:21 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
内存的malloc和free结构体:
接上文,内存也需要像FAT32文件这样操作。动态分配这个空间。

那么,一个什么样的结构,可以满足内存的动态分配呢?

struct RAM{
int *Pbefore;
int *Pstart;
int lenth;
int *Pnext;
};
int  *Pstart:空白内存的首地址
int   lenth:空白内存的长度
int   *Pnext:下一个空白内存地址
int *Pbefore:上一个空白内存地址

动态分配RAM的过程:
1:顺着链表一个方向,寻找大于申请空间的RAM

2:找到之后,将Pstart = Pstart + lenth;//修改剩余空间的指针

3:将lenth =lenth - Req_lenth;       //剩余的空间

4:同时回朔上一个空白地址结构,将其Pnext = Pstart; //修改上一个RAM的Pnext指向地址

4:返回最早的地址。


这只是一个最简单的模型:在这个模型里面,我们只要一找到有空白空间,就进行分配

   其实,是不是可以再找找看,有没有更合适的空间,刚刚比需要的空间大一点点,这样,内存的使用是不是更有效果呢?!

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表