内存管理
2017-02-11 20:39
155 查看
分配原理
当指针 p 调用 malloc 申请内存的时候,先判断 p 要分配的内存块数(m),然后从第 n 项开
始,向下查找,直到找到 m 块连续的空内存块(即对应内存管理表项为 0),然后将这 m 个内
存管理表项的值都设置为 m(标记被占用)
,最后,把最后的这个空内存块的地址返回指针 p,
完成一次分配。注意,如果当内存不够的时候(找到最后也没找到连续的 m 块空闲内存),则
返回 NULL 给 p,表示分配失败。
释放原理
当 p 申请的内存用完,需要释放的时候,调用 free 函数实现。free 函数先判断 p 指向的内
存地址所对应的内存块,然后找到对应的内存管理表项目,得到 p 所占用的内存块数目 m(内
存管理表项目的值就是所分配内存块的数目),将这 m 个内存管理表项目的值都清零,标记释
放,完成一次内存释放。
当指针 p 调用 malloc 申请内存的时候,先判断 p 要分配的内存块数(m),然后从第 n 项开
始,向下查找,直到找到 m 块连续的空内存块(即对应内存管理表项为 0),然后将这 m 个内
存管理表项的值都设置为 m(标记被占用)
,最后,把最后的这个空内存块的地址返回指针 p,
完成一次分配。注意,如果当内存不够的时候(找到最后也没找到连续的 m 块空闲内存),则
返回 NULL 给 p,表示分配失败。
释放原理
当 p 申请的内存用完,需要释放的时候,调用 free 函数实现。free 函数先判断 p 指向的内
存地址所对应的内存块,然后找到对应的内存管理表项目,得到 p 所占用的内存块数目 m(内
存管理表项目的值就是所分配内存块的数目),将这 m 个内存管理表项目的值都清零,标记释
放,完成一次内存释放。
相关文章推荐
- css rem 的理解
- iOS开发之路
- Codewars --Number of trailing zeros of N!
- Json转换利器Gson之实例三-Map处理(上)
- time clock getrusage clock_gettime gettimeofday timespec_get 对比
- 学习JavaScript中的异步Generator
- express框架下index.js和index.ejs的注释版
- UML—— 概述
- YII相关资料(干货)
- Html中button标签设置background问题
- html5页面分屏 还有上下拖动
- 通达OA jquery控制列表控件和单选框的实例代码
- hdu3038带权并查集
- 用tensorflow实现seq2seq模型
- FPGA, 电路为什么要有触发器这种结构? 流水线
- POJ 1201 差分约束(链式前向星
- C, C++混合编程通用Makefile模版
- Codeforces 396 div.2 带权并查集
- CodeForces - 697B Barnicle (高精度小数点)
- Linux下软链接与硬链接的区别