考虑以下代码,
#include "iostream"
#include "conio.h"
using namespace std;
class sample
{
private:
int i;
public:
sample(int ii=0) : i(ii){
cout<<"Constructing Object"<<endl;
}
~sample() { cout<<"Destructing Object"<<endl; }
void* operator new(size_t nSize, void* loc){
cout <<"Inside new"<<endl;
cout <<loc<<endl;
return loc;
}
void operator delete(void* ptr){
cout <<"Inside delete"<<endl;
free(ptr);
}
};
int main()
{
int intArr[2];
sample* samplePtr = new(intArr) sample(5);
cout <<samplePtr<<endl;
delete samplePtr;
// samplePtr->sample::~sample();
getch();
}
输出:
Inside New
0x22ff38
Constructing Object
0x22ff38
Destructing Object
Inside Delete
在这里,我动态地请求一个已经在堆栈上分配的内存。我读到我需要在完成后显式调用析构函数。但是,当我尝试为堆栈上分配的内存调用 delete 时,我会调用析构函数。这是否意味着调用析构函数后释放堆栈上的内存?
如果我动态请求之前在堆上分配的内存,在这种情况下我需要调用删除,但删除实际上释放了堆栈上的内存吗?