C++中动态分配数组的分析

本文通过实例解析了C++中使用delete[]操作符时如何确定动态分配的数组大小。展示了系统如何在new操作时记录数组长度,并在delete[]时利用该信息正确释放内存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//-----------------------一下为原文

看一个小例子:

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个字节中。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值