c++ - boost 序列化保存到多种存档类型并防止在使用指针加载时构建新对象

标签 c++ design-patterns boost boost-serialization

我正在使用 boost 序列化来保存来自多个存档输出( xml 、二进制和文本)的对象。当库通过指针加载时,它会创建一个新对象,我想防止我的某些对象出现这种情况,比如我的对话框类。所以我正在加载带有引用的对话框。但是代码很难看:

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 类中都有虚函数对,这也不好。

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

最佳答案

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

关于c++ - boost 序列化保存到多种存档类型并防止在使用指针加载时构建新对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10086469/

相关文章:

c++ - 为什么 std::atomic 初始化不进行原子释放,以便其他线程可以看到初始化值?

design-patterns - 在 F# 中 float 的整数列表

c++ - 如何使用 boost::spirit 将单词序列解析为 vector ?

c++ - 我应该使用 boost::variant 吗?

c++ - 为什么创建本地类型 vector 失败

c++ - 奇数组中包含的数字

C++继承问题

c++ - 在函数开头测试并返回 vs 嵌套 if

c# - 用于处理许多参数和业务规则的设计模式

c++ - 使用 vertex_descriptor boost graph 打印或迭代顶点