首页 > 解决方案 > 如何在不调用模板化值析构函数的情况下将模板化值插入 std::map?

问题描述

我有一个非常简单的内存管理器。ConstructObject 函数将 ObjectInfo 插入 m_ObjectInfoMap。但我这样做的方式是调用 ObjectInfo 析构函数。如何更改功能以防止这种情况发生?我想我可以使用指针 (ObjectInfo* pObjectInfo = new ObjectInfo()) 并将其插入到地图中,但我试图避免调用 new 运算符。

#define CONSTRUCT(T) static_cast<T*>(ObjectFactory::ConstructObject<T>( #T ))
#define DESTRUCT(object) ObjectFactory::DestructObject( object )

//dummy class so we can have a templated class as value to a map
class OObjectInfoInterface
{
};

template<class T>
class ObjectInfo : public OObjectInfoInterface
{   
public:
    ObjectInfo(){
        m_Object = NULL; 
        m_Name = NULL;
        m_Size = 0;
    }
    ~ObjectInfo();

    T* m_Object;    

    //used for things like memory profiling
    const char* m_Name;
    size_t m_Size;
};

template<class T>
ObjectInfo<T>::~ObjectInfo()
{
    delete m_Object;
}

class ObjectFactory
{
public:
    template <typename T> 
    static OObjectInterface* ConstructObject( const char* pName )
    {
            T* pNewObject = new T();
            ObjectInfo<T> objectInfo;
            objectInfo.m_Object = pNewObject;
            objectInfo.m_Name = pName;
            m_ObjectInfoMap[pNewObject] = objectInfo;//<--causes destructor of ObjectInfo to be called (which deletes pNewObject)
            return pNewObject;
    }

    void ObjectFactory::DestructObject( void* pObject )
    {
        if ( pObject )
        {
            TObjectInfoMap::iterator it = m_ObjectInfoMap.find( pObject );

            if ( it != m_ObjectInfoMap.end() )
            {
                m_ObjectInfoMap.erase(pObject);
            }
            else
            {
                LOG_ASSERT( 0, "object not found!");
            }
        }
    }
};

标签: c++templatesdestructorstdmap

解决方案


推荐阅读