1.申请内存的所在位置
-
new 从自由存储区上为对象动态分配内存空间,malloc 函数从堆上分配内存.自由存储区是c++基于new操作符的一个抽象概念,凡是通过new操作符进行内存申请,该内存为自由存储区域,堆是操作系统中的概念,自由存储区是不是堆,取决于new 操作符的实现细节,自由存储区不仅可以是堆,还可以是静态存储区,这都看new操作符在那里为对象分配内存,甚至new可以不为对象分配内存
-
new (place_adress) type 表示一个指针,代表一块内存上的地址,当使用上面这种地址调用new操作符的时候 不分配任何的内存控件,简单的返回指针实参数
2.返回类型安全性
- new 操作符内存分配成功的时候,返回的是对象类型的指针,类型严格与对象匹配,不能进行类型转化,所以new式符合类型安全性的操作符,malloc内存分配的是返回void * , 需要通过强制类型转化将void * 指针转化为我们需要的类型
3 内存分配失败的返回值
- new 内存分配失败的时候会抛出
bac_malloc
异常,malloc分配失败会抛出NULL
4.是不是需要指定内存大小
- new 申请内存分配不需要指定内存块的大小,编译器会自行计算,malloc需要显式指定内存的大小
5.是不是调用了构造/析构函数
new 操作符会经历三个步骤- 第一步调用 new 操作符号 分配一块足够大的,原始的,内存,用于存储
- 第二步,编译器调用相应的构造函数用来进行构造对象,并且传入处置
- 第三步,对象构造完成之后,返回一个指向该对象的指针
delete 操作符来释放对象内存会经历两个步骤 - 第一步 调用对象的析构函数
- 第二步 编译器调用了 delete 函数来进行空间的释放
malloc是不会调用构造和析构函数
6.对于数组的处理
-
c++提供了new[]和delete[]来专门处理数组类型
-
new体现
在它会调用构造函数初始化每一个数组元素,释放的时候需要调用delete ,delete 和new必须配套使用,不然会造成内存泄漏
-
malloc 给一块原始的内存,和相应的地址
7.new 和malloc 是不是可以相互调用
- new 可以调用malloc ,malloc的实现不可以去调用new
8.可不可以被重载
-
new 和delete 可以被重载
malloc不可以被重载
总结
特征 | new/delete | malloc/free |
---|---|---|
分配内存的位置 | 自由存储区 | 堆 |
内存分配失败返回值 | 完整类型指针 | void* |
内存分配失败返回值 | 默认抛出异常 | 返回NULL |
分配内存的大小 | 由编译器根据类型计算得出 | 必须显式指定字节数 |
处理数组 | 有处理数组的new版本new[] | 需要用户计算数组的大小后进行内存分配 |
已分配内存的扩充 | 无法直观地处理 | 使用realloc简单完成 |
是否相互调用 | 可以,看具体的operator new/delete实现 | 不可调用new |
分配内存时内存不足 | 客户能够指定处理函数或重新制定分配器 | 无法通过用户代码进行处理 |
函数重载 | 允许 | 不允许 |
构造函数与析构函数 | 调用 | 不调用 |