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 []数组名。

  • 联系
    new和delete功能覆盖了malloc/free,但因C++程序常会用到C函数,而C函数只能使用malloc/free管理动态内存。此外,使用是malloc和free搭配使用,new和delete搭配使用,不能混乱使用。

    (参考):https://blog.csdn.net/yzhang6_10/article/details/51136018

猜你喜欢

转载自blog.csdn.net/ddcodingya/article/details/80454667