c++中的malloc和 new的区别


(1)malloc和new都是在堆上开辟内存的
malloc只负责开辟内存,没有初始化功能,需要用户自己初始化;new不但开辟内存,还可以进行初始化,如new int(10);表示在堆上开辟了一个4字节的int整形内存,初始值是10,再如new int[10] ();表示在堆上开辟了一个包含10个整形元素的数组,初始值都为0。
(2)malloc是函数,开辟内存需要传入字节数,如malloc(100);表示在堆上开辟了100个字节的内存,返回void*,表示分配的堆内存的起始地址,因此malloc的返回值需要强转成指定类型的地址;new是运算符,开辟内存需要指定类型,返回指定类型的地址,因此不需要进行强转。
如堆上开辟int整形:
int *p1 = (int*)malloc(sizeof(int));   
=>  根据传入字节数开辟内存,没有初始化

int *p2 = new int(0); 
=>  根据指定类型int开辟一个整形内存,初始化为0

int *p3 = (int*)malloc(sizeof(int)*100);  
=>  开辟400个字节的内存,相当于包含100个整形元素的数组,没有初始化

int *p4 = new int[100]();  
=>  开辟400个字节的内存,100个元素的整形数组,元素都初始化为0  
1234567891011
(3)malloc开辟内存失败返回NULLnew开辟内存失败抛出bad_alloc类型的异常,需要捕获异常才能判断内存开辟成功或失败,new运算符其实是operator new函数的调用,它底层调用的也是malloc来开辟内存的,new它比malloc多的就是初始化功能,对于类类型来说,所谓初始化,就是调用相应的构造函数。
(4)malloc开辟的内存永远是通过free来释放的;而new单个元素内存,用的是delete,如果new[]数组,用的是delete[]来释放内存的。
详细使用规则参照我的上一篇博客 https://blog.csdn.net/weixin_39411321/article/details/89310651
(5)malloc开辟内存只有一种方式,而new有四种分别是普通的new(内存开辟失败抛出bad_alloc异常), nothrow版本的new,const new以及定位new。

(6)malloc的返回值为void*,new为对象类型
注意这里 : 如果问到malloc,还有可能问你memcpy等,realloc函数能不能在C++中使用,绝对不能,因为这些函数进行的都是内存值拷贝(也就是对象的浅拷贝),会发生浅拷贝这个严重的问题!
malloc的底层实现

malloc/free底层实现是这样的:通过brk和mmap,mummap这些系统调用来实现的brk系统调用是malloc分配小于128k的内存地址时的系统调用,此时把_edata指针从低地址往高地址推,分配虚拟内存空间,但并不是说malloc调用之后,就分配物理内存,而是在进程执行时,发生缺页中断,进程陷入内核态,内存才会分配物理地址,然后建立虚拟内存与物理内存的映射关系。这里的内存只能小于128K的,然后依次从低地址向高地址分配,不能随意释放,只能在高地址空间有超过128K的空闲地址时,才发生内存紧缩,否则不能释放,因此产生内存碎片。而大于128K的内存空间是通过mmap调用实现的,是在堆栈之间随机分配一段空闲空间分配内存,mmap分配的内存地址也可以随机释放。

缺页中断的过程之后,执行了那些操作?

1.检查访问的虚拟内存是否合法

2.查找malloc分配的虚拟内存

3.填充分配物理内存

4.建立映射关系

5.重新执行缺页中断发生的那条指令。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值