14.new与delete
1.前言
在C语言中,我们写程序是总是会有动态开辟内存的需求,每到这个时候我们就会想到用malloc/free去堆空间中动态申请出来一段内存给我们用。但是对这一块申请出来的内存,往往我们还需要对它进行稍许的“加工”后(即初始化)才能为我们所用。虽然C语言中为我们提供了calloc来开辟这样一段初始化好的(初始化为0)的内存,但是面对使用类创建的对象中各式各样的数据成员的初始化,calloc同样也束手无策。但是,为了保持良好的编程习惯,我们应该对申请出来的内存进行手动初始化。
那么对于使用类创建的对象的,我们如何解决动态分配内存与初始化的矛盾呢?
c++中已经为我们解决了这个问题,即使用new与delete,new[]与delete[]来实现动态的内存管理。
2.new/delete,new[]/delete[]基本格式
- new/delete动态管理对象
- new[]/delete[]动态管理对象数组
在C++中,把int,char…等内置类型的变量也看作对象,它们也是存在构造函数和析构函数的。只是通常对它们,系统调用了默认的构造函数来初始化,并调用了默认的析构函数来释放(编译器优化)。所以new int,new int(3)看起来和普通的定义好像没有什么区别。
但是对于自定义类型的对象,使用new/delete的方式可以很方便地在创建对象的同时,完成对象的初始化。
这也是new/delete、new[]/delete[]方式管理内存的优势,即它能保证对象一被创建出来便被初始化,出了作用域便被自动清理
3.malloc/free和new/delete的区别与联系
- malloc/free只是动态分配内存空间/释放内存空间。而new/delete除了分配内存空间和释放内存空间还会调用构造函数和析构函数进行初始化和清理(清理成员)。
- 它们都是动态管理内存的入口。
- malloc/free是C/C++标准库的函数,而new/delete只是C++的操作符
- malloc/free需要手动计算类型大小且返回值为void*类型,而new/delete可以自动计算类型大小,并返回对应类型的指针。
- malloc/free管理内存失败会返回0,new/delete管理内存失败会抛出异常