我想就我面临的问题寻求帮助。
我正在使用序列化(准确地说是 TinyXml)将对象保存在文件中,但我在反序列化方面遇到了问题。
我的对象包含指针,这些指针没有直接保存,而是保存了指向的对象的 ID。
我保存的每个对象都直接或不直接派生 ASerializable。
这是我的层次结构:
//Holds pure virtual method: TiXmlElement * ToXml() = 0;
class ISerializable;
// Basic implementation of ISerializable, this class has a unique ID.
class ASerializable : public ISerializable;
// For security sake, this class is not real, just a demonstration of my problem.
// Overrides TiXmlElement * ToXml()
class Base : public ASerializable;
// Overrides TiXmlElement * ToXml()
class Derived : public Base;
反序列化后,我将我创建的每个对象添加到一个静态映射(ID,ASerializable*)中,该映射保存数据直到取消引用。
我如何解引用对象
我使用一个包含 T** 的模板类,它是所有反序列化完成后取消引用的指针。
template<typename T>
class Reference<T> {
T** ref_ptr;
int id; // This is the ID of the referenced object
void Dereference();
}
基本上,Reference<T>::Dereference()
获取 map 中的对象,然后将其转换为良好类型(即 T*
)并更改 *ref_ptr
的值到 Actor 对象。
我正在使用 dynamic_cast<T*>( objects_map[id] )
转换我的对象,但由于某种原因,它每次都失败。
我无法从 ASerialisable*
转换到 Derived*
不会丢失 Derived
的数据.
这是我想要实现的模式:
在反序列化时,项目将自身添加到对象映射;
如果对象是一个引用,添加一个引用(好的类型,我知道)到堆栈
所有反序列化完成后,解压所有引用和调用
Dereference()
真的很开心。
非常感谢您抽出宝贵的时间和宝贵的帮助,非常感谢。
{享受} 编辑 : 好的,我会尽量说得更清楚,但这有点复杂。
当我解析我的 XML 文件时,有时会出现名为 <reference id="X">
的元素: 这些是对另一个实例的引用 ( ASerializable
);
当我遇到 <reference>
对象,我将它添加到堆栈中,以便稍后取消引用。
当我遇到一个特定的对象时,比如 <Base id="X" ... data ... />
我构建它,然后将它作为 ASerializable*
添加到对象映射中;
一旦我完成所有对象的构建,我就会拆开每个引用并调用 Dereference()
,应该去获取对象的真实实例,使用 dynamic_cast
将其转换为正确的类型然后更改他的 ref_ptr 的值以指向该对象。
如有需要,请随时提出其他问题。
最佳答案
关于c++ - dynamic_cast 派生类型失败,为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5524809/