内存管理
1 内存分配方式
内存分配方式有三种:
- 从静态存储区分配,在程序编译时就分配好,且这块内存在程序的整个运行期间都存在。
- 在栈上创建。
- 从堆上分配,也叫动态内存分配。动态内存的生存期由程序员决定。
2 常见的内存错误及其对策
内存分配未成功,却使用了指针
解决方法:使用内存前先检查指针是否为NULL。若指针p是函数参数,则在函数入口处用assert(p!=NULL)进行检查,若用malloc或new来申请内存,则用if(p==NULL)
进行防错处理。
内存分配成功,但未初始化就进行引用
无论以何种方式创建数组,都别忘了赋初值,即便是赋零值也不可省略。
内存分配成功且已初始化,但操作越过了内存的边界
避免数组或指针的下标越界。
忘记释放内存,造成内存泄漏
动态内存的申请与释放必须配对,程序中 malloc 与 free 的使用次数一定要相同。
释放了内存却继续使用它
3 free和delete
free和delete只是把指针所指向的内存释放掉,并没有把指针删除掉,例如指针p被free后其地址依然不变(非NULL),只是该地址对应得内存是垃圾(无意义),p成为野指针。
指针有一些特征:
4 malloc/free和new/delete的区别
malloc/free是 C++/C 语言的标准库函数,new/delete是 C++ 的运算符,它们都可用于申请动态内存和释放内存。
用 maloc/free 无法满足动态对象的要求。对象在创建的同时要自动执行构造函数,对象在消亡之前要自动执行析构函数。malloc/free 不能执行构造函数与析构函数。因此 C++语言需要一个能完成动态内存分配和初始化工作的运算符new,以及一个能完成清理与释放内存工作的运算符delete。
5 malloc/free使用要点
#include <stdlib.h>
void *malloc(size_t size);
void free(void *memblock);
- malloc返回值类型为void指针,故调用malloc时要显式地进行类型转换。
- malloc函数本身不识别要申请的内存的类型,它只关心内存的总字节数。
6 new/delete使用要点
new 内置了 sizeof、类型转换和类型安全检查功能。对于非内部数据类型的对象而言,new 在创建动态对象的同时完成了初始化工作。