本文章是本人自己对C++中new与delete关键字的一点个人想法
在C中,我们使用malloc和free来动态申请、释放堆区的内存空间,使用时需要显式的指定申请空间的大小。
在C++中,我们使用的是new和delete来申请堆区的内存空间,new申请空间不需要指定空间大小,而是指定类型,根据类型自动计算所需要的空间大小,并返回申请内存空间的地址,地址指向的类型为new后写的类型,格式:typeName* pointer_name = new typename
举个栗子:
使用malloc()函数申请空间和free()函数来释放空间(需要引入stdlib.h或malloc.h头文件)
int* p = (int*)malloc(sizeof(int));
free(p);
使用new来申请内存空间
int* p1 = new int;
int* p2 = new int(10);//申请堆区空间并初始化为10
new数组返回的是首元素的首地址
int* p1 = new int[10];
int* p2 = new int[10]();//新建int类型数组并初始化,每个元素为0
char* p3 = new char[10]();//新建char类型数组并初始化,每个元素为空字符'\0'
对于数组空间回收,一般在指针前加上[],代表回收整个数组空间
delete []p1;
delete []p2;
delete []p3;
注意:delete回收空间并不包含指针本身,而是指针指向的内存空间,同一块内存空间不要重复释放,除非指针已经被赋空,对空指针使用delete是安全的的。对栈区的内存空间不能使用delete来释放。
两者的区别:
1.new、delete是关键字需要C++的编译器支持,malloc、free()是函数,需要引入对应的头文件。
2.new申请空间不需要指定申请大小,根据类型自动计算,malloc()需要显式的指定申请空间的大小(字节)。
3.new返回的是类型的地址,malloc()返回void*,需要我们强转成我们需要的类型。
4.new申请类对象内存空间会调用构造函数,delete会调用类的析构函数,单独的malloc()和free()则不会调用构造、析构函数。