new/delete和malloc/free的区别是什么?
int main()
{
//malloc/free
int *p = (int*)malloc(sizeof(int));
if(p == nullptr)
{
return -1;
}
*p = 20;
free(p);
//new/delete
int *p1 = new int(20);
int *p2 = new int [20]();//开辟数组,并初始化为0
delete p1;
delete [] p2;//释放数组内存
return 0;
}
1.malloc/free,称作C的库函数,需要头文件支持。new/delete,称作运算符,需要编译器支持。
2.malloc按照字节开辟内存,使用new操作符申请内存分配时无须指定内存块的大小,编译器会根据类型信息自行计算。
3.malloc内存分配成功返回void * ,需要通过强制类型转换将void*指针转换成我们需要的类型,而且只能进行内存分配,而不能进行初始化。new操作符内存分配成功时,返回的是对象类型的指针,类型严格与对象匹配,无须进行类型转换,同时可以进行初始化。
4.new操作符从自由存储区(free store)上为对象动态分配内存空间,而malloc函数从堆上动态分配内存。
5.C++允许重载new/delete操作符,而malloc不允许重载。
6.new会先调用operator new函数,申请足够的内存(通常底层使用malloc实现)。然后调用类型的构造函数,初始化成员变量,最后返回自定义类型指针。delete先调用析构函数,然后调用operator delete函数释放内存(通常底层使用free实现)。malloc/free是库函数,只能动态的申请和释放内存,无法强制要求其做自定义类型对象构造和析构工作。
7.new内存分配失败时,会抛出bad_alloc类型的异常来判断。malloc分配内存失败时返回NULL,通过返回值与nullptr作比较判断。
8.free在释放单个内存与数组内存时没有区别,都是一个标准的函数调用,只需填入这个内存的起始地址;delete在释放数组内存时,需要在delete与指针之间加入中括号[]。
常见面试题:new有多少种?
int main()
{
int *p = new int(20);//抛出异常的new
int *p2 = new (nothrow) int;//不抛出异常的new
const int *p3 = new const int(40);//在堆上生成常量的new
//定位new
int data = 0;
int *p4 = new (&data) int (50);//在给定的地址上开辟内存
}
new和delete能够混用吗?
new delete
new[] delete[]
对于普通的编译器内置类型,new/delete[] 与 new[]/delete可以混用
对于自定义的类类型,有析构函数,为了调用正确的析构函数,那么开辟对象数组的时候,会多开辟四个字节,记录对象的个数.
本文详细对比了C++中的new/delete与C语言中的malloc/free,解析了它们在内存分配、类型安全、初始化、异常处理等方面的差异,并探讨了new/delete的高级用法。
2731

被折叠的 条评论
为什么被折叠?



