首先说说内存申请函数:
- malloc、calloc、realloc返回一个 void 指针,C++不允许将 void 指针赋值给其他任何指针,必须强转。
- malloc、calloc、realloc可能申请内存失败,所以必须根据返回值确定是否申请成功。
- malloc、calloc、realloc不会调用构造函数 ,free释放堆区不会调用析构函数(重要)。
C++提供了另外的申请内存空间的关键字:new
new 与 malloc函数相比,其主要的优点是, new 不只是分配了内存,它还创建了对象。
new内存分配失败时,会抛出bac_alloc异常,会返回NULL。
malloc分配内存失败时返回NULL。
使用new操作符申请内存分配时无须指定内存块的大小,编译器会根据类型信息自行计算。
malloc则需要显式地指出所需内存的尺寸。
在任何时候,某个已经动态分配内存的变量不再需要使用时,可以使用 delete 操作符释放它所占用的内存。
基本类型申请空间:
double* pvalue = NULL; // 初始化为 null 的指针
pvalue = new double; // 为变量请求内存
释放内存:
delete pvalue; // 释放 pvalue 所指向的内存
为数组申请空间:
int* arr = new int[4] {4, 5, 6, 7}; //不能初始化字符串,用strcpy
释放内存:
delete []arr; // 释放 pvalue 所指向的内存
为对象申请空间:
Point* p = new Point(1, 1);
释放内存:
delete p; // 释放 pvalue 所指向的内存
new 自动调用构造函数 delete 自动调用析构函数
从上述代码可以看出,使用new时指定了类型,指定的类型作为了开辟空间大小的依据。也可以看出可以在申请空间的同时初始化空间的内容。
对象数组
即元素为对象的数组。
示例:
Point arr[2] = {Point(5, 5)}; //Point为一个类。初始的元素调用有参构造,未初始化元素调用无参构造,也就是说这个对象数组第二个元素虽然未指明,但是它是存在的,并且依据无参构造进行初始化的。
从堆区申请内存:
Point* arr = new Point[2] { Point(5, 5), Point(10, 3)}; //申请一个存放对象的数组空间,并初始化。