看一个小例子:
1 |
#include <iostream> |
2 |
3 |
using namespace std; |
4 |
5 |
class A { |
6 |
public : |
7 |
A() { cout << "A::A()" << endl; } |
8 |
~A() { cout << "A::~A()" << endl; } |
9 |
}; |
10 |
11 |
int main() { |
12 |
A* a = new A[5]; |
13 |
delete [] a; |
14 |
15 |
return 0; |
16 |
} |
编译执行输出:
A::A() A::A() A::A() A::A() A::A() A::~A() A::~A() A::~A() A::~A() A::~A()
上面的输出显示程序正确释放了5个A对象。
现在的问题是:我们在delete[] a语句中并没有给出对象数组的大小,那么系统是如何做到正确释放对象个数的呢?
接着看下面的程序段:
1 |
#include <iostream> |
2 |
3 |
using namespace std; |
4 |
5 |
class A { |
6 |
public : |
7 |
A() { cout << "A::A()" << endl; } |
8 |
~A() { cout << "A::~A()" << endl; } |
9 |
}; |
10 |
11 |
int main() { |
12 |
A* a = new A[5]; |
13 |
14 |
int addr = ( int )a - 4; |
15 |
cout << "delete[] size = " << *( int *)addr << endl; |
16 |
17 |
delete [] a; |
18 |
19 |
return 0; |
20 |
} |
编译执行:
A::A() A::A() A::A() A::A() A::A() delete[] size = 5 A::~A() A::~A() A::~A() A::~A() A::~A()
结论:
系统在new一个数组对象的时候会把数组大小存放在返回的内存地址的前4个字节中。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!