使用构造函数,构造函数连续构造:
#include <iostream>
#include <complex>
#include "class_a.h"
using namespace std;
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
#define size 3
int main(int argc, char** argv) {
//complex* pa = new complex[3];
//内存泄漏就是只是释放了一块儿内存地址,当然删除一次和删除三次其实效果是一样的。
//使用array new 就要使用array delete
A* buf = new A[size];//调用默认构造函数 构造是由上向下的
A* tmp = buf;
cout<<"buf="<<buf<<" tmp="<<tmp<<endl;//证明buf和temp的内存地址是完全一样的
for(int i=0;i<size;i++)
{
new(tmp++)A(i);//ctor3次调用构造函数 (会直接将上面默认构造的元素替代)
}
cout<<"buf="<<buf<<" tmp="<<tmp<<endl;
delete[] buf;//析构是由下向上的
return 0;
}
上述代码说明,array new和array delete,是一对必须一起使用,否则会造成内存泄露。上述代码是整型变量,不存在析构函数,也就不存在内存泄漏,所以即使不使用析构函数也影响不大。