c++中的动态内存管理(new/delete)

C++动态内存管理

  • 通过new/delete动态管理对象
  • 通过new[]/delete[]动态管理对象数组
int *p1 = new int;    //动态分配4个字节
int *p2 = new int(1);   //动态分配4个字节,初始化为1
char *p3 = new char[3];  //动态分配3个字节(3个char类型)

    delete p1;
    delete p2;
    delete[]p3;

注意:new/delete,和new[]/delete[]是匹配使用的。

  • c++的其他内存管理接口:
void *operator new(size_t size);
void operator delete(size_t size);
void *operator new[](size_t size);
void operator delete[](size_t size);

1、operator new /operator delete/ oerator new[]/operator delete[]和malloc/free用法一样
2、他们只负责分配空间/释放空间,不会调用构造函数来初始化/析构函数来清理对象。
3、实际operator new 和 operator delete只是malloc 和free的一层分装。

这里写图片描述

  • new做了两件事:

    1、调用operator new分配分配空间
    2、调用构造函数初始化对象

    这里写图片描述

  • delete也做了两件事:
    1、调用析构函数清理对象;
    2、调用operator delete释放空间;
    这里写图片描述

  • new[N]:
    1、调用operator new 分配空间;
    2、调用N次构造函数分别初始化每个对象

  • delete[]:
    1、调用N次析构函数清理对象
    2、调用operator delete释放空间。

new/delete和malloc/free的区别

  • 相同点:
    malloc/free与new/delete都可以用于申请动态内存和释放内存。且所申请的空间都在堆上。

  • 不同点:
    (1)、操作对象同
    malloc/free是c/c++语言的标准库函数,new/delete是c++的运算符。
    对非内部数据对象,malloc/free无法满足动态对象要求。对象在创建时要自动执行构造函数,对象消亡之前要自动执行析构函数,而malloc/free是库函数,不是运算符,故不在编译器控制权限之内,不能够将执行构造函数和析构函数强加于malloc/free身上。而由于new/delete是C++语言,能够完成动态内存分配和初始化工作,并能够完成清理与释放内存工作,即能够自动执行构造函数和析构函数;
    (2)、用法不同

malloc分配内存空间前需要计算分配内存大小;而new能够自动分配内存空间;

malloc是底层函数,其函数返回值类型为void *;而new运算符调用无参构造函数,故返回值为对应对象的指针;

malloc函数类型不是安全的,编译器不对其进行类型转换、类型安全的相关检查。malloc申请空间后,不会对其初始化,要单独初始化;而new类型是安全的,因为它内置了sizeof、类型转换和类型安全检查功能,且在创建对象时,就完成了初始化工作,一般初始化调用无参构造函数;

operator new对应于malloc,且operator new可以重载,可以自定义内存分配策略,甚至不做内存分配,甚至分配到非内存设备上;但malloc不能。

free只进行释放空间;而delete则释放空间的同时调用析构函数。此外delete使用是注意释放数组的方法为delete []数组名。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值