在c++中,我们使用new[]/delete[]来管理动态内存。
在学习过程中,我了解到在gcc编译器中,new[]会在返回值前四个字节存放数组的长度。
于是我做了以下的尝试:
#include <iostream>
using namespace std;
struct Test //定义结构
{
int num;
};
int main()
{
Test* test = new Test[5]; //创建长度为5的数组
cout << *((int*)test-1) <<endl; //打印返回值前4字节的值
}
按照上文所说,打印值应为5,但是执行后打印的结果却是25。
经过一段时间的摸索,我了解到new[]数组之后的返回值是给delete[]时提供调用析构函数的次数。
于是,我在结构体中加入了显式的析构函数
#include <iostream>
using namespace std;
struct Test //定义结构体
{
int num;
~Test(); //析构函数
};
int main()
{
Test* test = new Test[5]; //创建长度为5的数组
cout << *((int*)test-1) <<endl; //打印返回值前四个字节的值
}
此时运行的结果是 5。正是我们所预期的数值。
经过上面两段函数的比较,我们可以知道new[]在结构体中缺省析构函数时,返回值前4字节存放的是申请到的字节数大小,而在结构体中定义析构函数后,new[]返回值前4字节存放的是数组的长度,这个值将在delete[]时被调用。