分配单变量地址空间:
格式1:指针变量名 = new 类型标识符;
格式2:指针变量名 = new 类型标识符(初始值);//其在内存分配成功后,同时将一初始值存放到该内存单元中。
分配数组空间:
一维数组格式:指针变量名 = new 类型名[下标表达式];
删除单变量地址空间:
delete 指针变量名;
2.删除数组空间
一维数组格式:delete []指向该数组的指针变量名;
delete的方括号中无需填数组元素数,系统自己知道,写了编译器也忽略。若此处少了方括号,则编译器认为该指针只是指向数组第一个元素,而产生回收不彻底的问题。
都需要包含头文件 #include <stdlib.h>
void *malloc(size_t size);
说明:malloc 向系统申请分配指定size个字节的内存空间。返回类型是 void* 类型。void* 表示未确定类型的指针。C,C++规定,void* 类型可以强制转换为任何其它类型的指针。
void free(void *ptr);
之所以把形参中的指针声明为 void* ,是因为free必须可以释放任意类型的指针,而任意类型的指针都可以转换为void *。
new和delete是C++的关键字,需要编译器支持;malloc和free是库函数,需要头文件支持。
使用new操作符申请内存分配时无须指定内存的大小,编译器会根据类型信息自行计算。而malloc则需要显式地指出所需内存地尺寸。
new操作符内存分配成功时,返回的是对象类型的指针,指针的类型严格与对象匹配,无须类型转换,故new是符合类型安全性的操作符。而malloc内存分配成功则返回void *类型的指针,需要通过强制类型转换将void *类型转换成我们需要的类型。
new会先调用operator new函数,申请足够的内存(通常底层使用malloc实现)。然后调用类型的构造函数,初始化成员变量,最后返回自定义类型指针。delete先调用析构函数,然后调用operator delete函数释放内存(通常底层使用free实现)。malloc和free是库函数,只能动态地申请和释放内存,无法强制要求其做自定义类型对象构造和析构工作。
C++允许自定义operator new和operator free函数控制动态内存地分配。
new做两件事:分配内存和调用类的构造函数,delete也做两件事:调用析构函数和释放内存。而malloc只是分配内存,free只释放内存。new操作符从自由存储区(free store)上为对象动态分配内存空间,而malloc函数从堆上动态分配内存。自由存储区是C++基于new操作的一个抽象概念,凡是通过new操作符进行内存申请,该内存即为自由存储区。而堆是操作系统中的术语,是操作系统所维护的一块特殊内存,用于程序的动态分配,C语言使用malloc从堆上分配内存,使用free释放已分配的对应内存。自由存储区不等于堆,如上所述,布局new就可以不位于堆中。
new内存分配失败的时候,会抛出bac_alloc的异常。malloc分配内存失败时返回NULL。
内存泄漏对于new和malloc都能检测出来,而new可以指明是哪一行,而malloc不行。