C++动态内存管理

malloc/free和new/delete之间关系和差异。

1. 它们都是动态管理内存的入口。
2. malloc/free是C/C++标准库的函数,new/delete是C++操作符。
3. malloc/free只是动态分配内存空间/释放空间。而new/delete除了分配空间还会调用构造函数和析构函数进行初始化与清理(清理成员)。
4. malloc/free需要手动计算类型大小且返回值会void*,new/delete可自己计算类型的大小,返回对应类型的指针。

new/delete、new[]/delete[]

这里写图片描述
1. operator new/operator delete operator 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表达式

  所谓定位new表达式指的是:在已经分配好的空间中调用构造函数,定位new表达式也实现了开辟空间再调用构造函数的机制,因此下面用函数或宏自己实现new[]/delete[]时可以用到。

AA* p = (AA*)malloc(sizeof(AA));//这里AA是一个类或类类型
new(p)AA;//构造函数
p->~AA();//析构函数

用宏来实现new[]/delete[]

这里写图片描述

#define NEWARRAY(P, TYPE, N)                        \
do{                                                 \
    P = (TYPE*)opertor new(sizeof(TYPE)*N + 4);     \
    *((int*)P) = N;                                 \
    PTR = (TYPE*)((char*)PTR + 4);                  \
    for (size_t i = 0; i < N; i++)                  \
        new(P + i)TYPE;                             \
} while (false);

#define DELETEARRY(P, TYPE)             \
do{                                     \
    size_t N = 0;                       \
    N = *((TYPE*)((char*)P - 4));       \
    P = (TYPE*)P;                       \
    for (size_t i = 0; i < N; i++)      \
        P[i].~TYPE();                   \
    P = (TYPE*)((char*)P - 4);          \
    operator delete P;                  \
} while (false);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值