2019.9.21记录

malloc实现于堆上
new实现于自由存储区?

开辟空间我们一般在堆区开发,堆区又称为自由存储区

(网上转载的内容各有各的说法)

malloc free是标准函数,不能重载
new delete是运算符可以重载,能够调用构造和析构函数
c++大多数运算符都可以重载
在这里插入图片描述

delete[]要与new[]配套使用,不然会找出数组对象部分释放的现象,造成内存泄漏。

就是说delete不能用于malloc,free可以用于new?

对于简单数据类型(例如int [ ]),使用new分配内存后,可以使用free来释放上述释放的内存,效果与delete相同。而复杂数据类型( 例如一个类指针),则不能用free来进行内存的释放,因为free与delete不同,不会执行类的析构函数

void * operator new (sieze_t size)
{
    if(void * mem = malloc(size)
        return mem;
    else
        throw bad_alloc();
}
void operator delete(void *mem) noexcept
{
    free(mem);
}

这是一次对new ,delete的重载,是基于malloc,free实现的。

在这里插入图片描述
delete p去释放malloc的内容,会释放p指向的第一个对象,并且调用析构函数,但是数组后面的对象没有释放,会造成内存泄露。

如果改成delete[] p的话。会一直打印"destructor",说明一直在调用析构函数,

在调用delete []p的时候,刚刚已经说过了,系统之前没有在这块内存调用构造函数,所以,delete找不到要释放变量的入口点,之前第一个成功仅仅是单纯的把启始地址当成释放入口点,后面的却找不到了,所以会发生错误。

这是段连续数组,如果delete p将起始地址当做释放入口点,为什么delete[] p不能呢,释放第一个后接着释放第二个,如果找不到入口点应该会报错,程序还是执行了。
猜测:delete[] p找不到数组的结尾地方,所以一直往后执行。每执行一次调用一次析构函数。

new对象的数组
Node *p=new Node[n]{Node(1,2),Node(3)};

int *p=new int[n]与 int p[]的区别

明显不一样呀。int a = 10,也叫静态创建,申明的变量的内存在栈里面;而int *p = new int(10),也叫动态创建,申明的变量的内存在堆里面。
栈中的变量的内存在离开作用域时,会被释放。比如说函数中的局部变量,函数结束时就被释放掉了。
而堆的内存必须手动释放。比如在函数中动态创建的内存,函数结束时,该内存不会被释放。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值