看一个小例子:
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个字节中。