new 和 malloc 区别

new与malloc的区别

申请的内存所在位置

  • new 从自由存储区上为对象动态分配内存空间,malloc函数从上动态分配内存。
  • 自由存储区不仅可以是,还可以是静态存储区,这都看operator new在哪里为对象分配内存

返回类型安全

  • new操作符内存分配成功时,返回的是对象类型的指针;是类型安全的malloc内存分配成功则是返回void * ,需要通过强制类型转换将void*指针转换成我们需要的类型
  • 类型安全很大程度上可以等价于内存安全,类型安全的代码不会试图方法自己没被授权的内存区域

内存分配失败时的返回值

  • new内存分配失败时,会抛出bac_alloc异常;malloc分配内存失败时返回NULL

是否需要指定内存大小

  • 使用new操作符申请内存分配时无须指定内存块的大小,编译器会根据类型信息自行计算,而malloc则需要显式地指出所需内存的尺寸。

是否调用构造函数/析构函数

使用new操作符来分配对象内存时会经历三个步骤:

  1. 调用operator new 函数(对于数组是operator new[])分配一块足够大的,原始的,未命名的内存空间以便存储特定类型的对象。
  2. 编译器运行相应的构造函数以构造对象,并为其传入初值。
  3. 对象构造完成后,返回一个指向该对象的指针。

使用delete操作符来释放对象内存时会经历两个步骤:

  1. 调用对象的析构函数。
  2. 编译器调用operator delete(或operator delete[])函数释放内存空间。

对数组的处理

  • C++提供了new[]与delete[]来专门处理数组类型:使用new[]分配的内存必须使用delete[]进行释放
  • 至于malloc,它并知道你在这块内存上要放的数组还是啥别的东西,反正它就给你一块原始的内存,在给你个内存的地址就完事。所以如果要动态分配一个数组的内存,还需要我们手动自定数组的大小

是否可以被重载

  • opeartor new /operator delete可以被重载;而malloc/free并不允许重载

能够直观地重新分配内存

  • 使用malloc分配的内存后,如果在使用过程中发现内存不足,可以使用realloc函数进行内存重新分配实现内存的扩充。realloc先判断当前的指针所指内存是否有足够的连续空间,如果有,原地扩大可分配的内存地址,并且返回原来的地址指针;如果空间不够,先按照新指定的大小分配空间,将原有数据从头到尾拷贝到新分配的内存区域,而后释放原来的内存区域。

  • new没有这样直观的配套设施来扩充内存。

总结

特征new/deletemalloc/free
分配内存的位置自由存储区
内存分配成功的返回值完整类型指针void*
内存分配失败的返回值默认抛出异常返回NULL
分配内存的大小由编译器根据类型计算得出必须显式指定字节数
处理数组有处理数组的new版本new[]需要用户计算数组的大小后进行内存分配
已分配内存的扩充无法直观地处理使用realloc简单完成
是否相互调用可以,看具体的operator new/delete实现不可调用new
分配内存时内存不足客户能够指定处理函数或重新制定分配器无法通过用户代码进行处理
函数重载允许不允许
构造函数与析构函数调用不调用
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值