目录
一、结论
malloc
和 new
都是用于在运行时动态分配内存的机制。但它们之间存在一些本质的区别,主要是在使用方面,现在我们直接说结论,然后在通过一个案例来理解和加深区别。
二、示例
1.实现类T
我们先来创建一个类T,代码比较简单,主要有一个静态的成员变量count。count作用用来计算创建类T实例数量的多少。代码如下:
class T
{
public:
T()
{
a = 10;
std::cout << "第" << ++count << "个T被构造了" << std::endl;
}
~T()
{
std::cout << "第" << count-- << "个T被销毁了" << std::endl;
}
static int count;
int a;
};
// 初始化静态变量count
int T::count = 0;
需要注意:静态成员变量需要在类外初始化!
2.用malloc分配类T的内存空间
我们用malloc关键字动态分配10个类T大小的空间,同时测试构造函数和析构函数是否发生变化。代码和结果如下:
int main()
{
T* t1 = (T*)malloc(sizeof(T) * 10);
std::cout << t1->count << std::endl;
// 释放空间
free(t1);
}
得出的结果count为0,同时构造函数和析构函数没有触发。可见malloc
只会分配请求的内存大小,并返回一个指向该内存的指针,它不会调用任何构造函数。
3.用new分配类T的内存空间
与malloc同样,我们用new关键字动态分配10个类T大小的空间,同时测试构造函数和析构函数是否发生变化。代码和结果如下:
int main()
{
T* t2 = new T[10];
std::cout << t2->count << std::endl;
// 释放空间
delete[] t2;
}
得出的结果count为10,同时构造函数和析构函数都会触发。所以new 不仅会分配内存,还会调用对象的构造函数(如果适用)。同样地,当使用 delete 运算符释放内存时,它会调用对象的析构函数。