我目前正在寻找一个好的 OO 设计来序列化 C++/Qt 应用程序。
想象一下基于树结构组织的应用程序的类,使用复合模式实现,如下图所示。
我想到的两个可能的原则:
1.)
将 save()/load() 函数放在每个必须可序列化的类中。如果多次看到这种情况,通常使用 boost 来实现。在课堂上的某个地方,您会发现类似这样的内容:
friend class boost::serialization::access;
template<class Archive>
void serialize(Archive & ar, const unsigned int version)
{
ar & m_meber1;
}
你也可以把它分成 save() 和 load()。但这种方法的缺点是:
如果你想在两个月后改变序列化(到 XML、HTML 或一些非常奇怪的东西,boost 不支持)你必须采用所有数千个类。在我看来,这不是一个好的 OO 设计。
如果您想同时支持不同的序列化(XML、二进制、ASCII 等等),那么 80% 的 cpp 仅用于序列化函数。
2.)
我知道 boost 还提供了序列化的非侵入式版本
“http://www.boost.org/doc/libs/1_49_0/libs/serialization/doc/tutorial.html”
所以另一种方法是实现一个迭代器,它迭代复合树结构并序列化每个对象(以及一个用于反序列化的迭代器)
(我认为这是 .NET-Framework 的 XmlSerializer-Class 所做的,但我不是非常熟悉 .NET)
这听起来更好,因为单独的 save() 和 load() 并且如果序列化发生更改,只有一个地方可以更改。
所以这听起来更好,但是:
- 您必须为要序列化的每个参数提供一个 setter() 和一个 getter()。(所以,不再有私有数据了。(这是好/坏吗?))
- 您可能有一个长的继承层次结构(超过 5 个类)挂在复合树上。
那么如何调用派生类的setter()/getter()呢?当您只能调用基础 Composite-Component 的接口函数时。
另一种方法是将对象数据序列化为单独的抽象格式。所有可能的后续序列化(XML、TEXT、任何可能的)都从中获取数据。一个想法是将其序列化为 QDomNode。但我认为额外的抽象会降低性能。
所以我的问题是:
有没有人知道用于序列化的好的 OO 设计?
也许来自其他编程语言,如 JAVA、Python、C# 等等......
谢谢你。