0

可能的重复:
C++ 的“新位置”

我刚刚了解了placement new 运算符并尝试创建自己的内存管理器。
这是我的内存模板基类的代码

#ifndef _MEMORY_BASE_H_  
#define _MEMORY_BASE_H_  
//=========================================!  
#include <new>  
#include <exception>  
#include <iostream>  
//=========================================!  
using namespace std;  
//=========================================!  
template <typename T>
class Memory_Base  
{  

public :  
//standard new
void* operator new(size_t T);  

// placement new  
void* operator new(size_t T,void* pAddress);  

//standard delete
void operator delete(void* pAny);
};  
//=========================================!
// Implementation 
//=========================================! 
template <typename T>
void* Memory_Base<T>::operator new(size_t T)
{
cout << "Memory_Base<T>:: new called" << endl;
void* pTemp = malloc(sizeof(T));
if(!pTemp)
    throw bad_alloc();
else 
    return pTemp;
}
//=========================================!  
template <typename T>
void* Memory_Base<T>::operator new(size_t T,void* pAddress)
{
cout << "Memory_Base<T>:: placement new called" << endl;
return pAddress;
}
//=========================================!
template <typename T>
void Memory_Base<T>::operator delete(void* pAny)
{
cout << "Memory_Base<T>:: delete called" << endl;
free(pAny);
}
//=========================================!
#endif

现在,我从上面的类继承了 myclass,在另一个头文件中,如下所示

#ifndef _MY_CLASS_H_
#define _MY_CLASS_H_
//=========================!
#include "Memory_Base.h"
//=========================!
class MyClass :public Memory_Base<MyClass>
{
 private :
int ma;
 public :
MyClass():ma(-1){}
~MyClass(){}
};  
//============================!
#endif  

现在,我主要尝试通过以下方式创建 myclass 的对象

//============================!
#include "MyClass.h"
//============================!
int main()
{
// This is how new for MyClass is called
MyClass* pMyClass = new MyClass();

// This is how placement new for MyClass is called
MyClass obj[10];
MyClass* pMyClass1 = new(&obj)MyClass();
return 0;
}
//============================!

问题 ::
1. 当我运行 main 时,obj 和 pMyClass1 的基地址与预期的一样。但是,我只是返回指针 pAddress,那么放置 new 是如何工作的?

  1. 我的 obj[10] 在堆栈中,但是没有调用析构函数。

有任何想法吗 ?

阿图尔

PS :: 我必须在 Memory_Base 中实现 new[] 和 delete[]。

4

1 回答 1

1
MyClass obj[10]; 

MyClass在本地存储上分配并创建 10 个该类型的对象。
更远,

MyClass* pMyClass1 = new(&obj)MyClass(); 

只需调用构造函数MyClass::MyClass()。构造函数中的this指针MyClass将等于&obj. 因此,返回的指针pMyClass1 将等于&obj

此外,在放置的情况下,new您有责任通过显式调用析构函数来销毁放置的对象,放置的对象的析构函数不会被隐式调用。

因为,一旦程序在您的情况下返回,自从放置在堆栈上的对象数组将被释放。

于 2012-03-20T10:52:23.167 回答