提高序列化保存到多种存档类型,并防止在使用指针加载时构造新对象

Posted

技术标签:

【中文标题】提高序列化保存到多种存档类型,并防止在使用指针加载时构造新对象【英文标题】:boost serialization save to multiple archive types and prevent construction of new object when loading with pointer 【发布时间】:2012-04-10 09:48:55 【问题描述】:

我正在使用 boost 序列化来保存来自多个存档输出( xml 、 binary 和 text )的对象。当库通过指针加载时,它会创建一个新对象,我想为我的一些对象阻止这种情况,比如我的对话框类。所以我正在参考加载对话框。但是代码很丑:

boost::archive::xml_iarchive ia;
for(vector<BaseDialog*>::iterator it= dialogs.begin();it!=dialogs.end();it++)

    if(typeid(it) == MyDialog1)
    
         MyDialog1* dlg = dynamic_cast<MyDialog1*>(it);
         ia & (*dlg);
    

    if(typeid(it) == MyDialog2)
    
         MyDialog2* dlg = dynamic_cast<MyDialog2*>(it);
         ia & (*dlg);
                  

所以我想出了以下解决方案:

class BaseDialog

 public:
    virtual void SaveState(boost::archive::xml_oarchive& oa)=0;
    virtual void LoadState(boost::archive::xml_iarchive& ia)=0;
    virtual void SaveState(boost::archive::binary_oarchive& oa)=0;
    virtual void LoadState(boost::archive::binary_iarchive& ia)=0;
    // other formats here
;

在我的派生类中,我正在实现这些功能。然后保存和加载是这样的:

boost::archive::xml_iarchive ia;
for(vector<BaseDialog*>::iterator it= dialogs.begin();it!=dialogs.end();it++)
     it->LoadState(ia);

因此,对于每个存档输出,我在 BaseDialog 类中都有虚函数对,这也不好。

所以任何人都知道如何解决这个问题

【问题讨论】:

【参考方案1】:

boost::serialization 可以毫无问题地通过其基类序列化派生类型。看看this链接。

【讨论】:

如果我通过基指针序列化它将创建新对象,这不是我想要的

以上是关于提高序列化保存到多种存档类型,并防止在使用指针加载时构造新对象的主要内容,如果未能解决你的问题,请参考以下文章

Wordpress:归档多种帖子类型

outlook存档后毫无反应

如何保存和加载用户创建的游戏对象?

在 Spark DataFrame 上保存到 JSON 并重新加载,模式列序列发生变化

将对象的类类型保存到文件并在 C++ 中读回

动态类型序列化