我有类似
的类结构class MemberClass;
class ContainerClass {
MemberClass special_member;
int other_members;
};
按照http://www.boost.org/doc/libs/1_66_0/libs/serialization/doc/中的示例 我想写一个非侵入式序列化:
template<class Archive>
void serialize(Archive & ar, ContainerClass & c, const unsigned int version)
{
ar & c.other_members; // easy - built-in type
serialize(ar, c.special_member, version); //???
}
假设还有一个非侵入性的
void serialize(Archive & ar, MemberClass & m, const unsigned int version);
这编译和工作,但我觉得这不是这样做的方法,因为它重用了成员类的容器类的版本号?
那怎么处理呢? Container类必须单独管理其成员的版本吗?
答案 0 :(得分:0)
答案是写作
template<class Archive>
void serialize(Archive & ar, ContainerClass & c, const unsigned int version)
{
ar & c.other_members;
ar & c.special_member;
}
即使我们只有
的非侵入式版本,也能正常工作void serialize(Archive & ar, MemberClass & m, const unsigned int version);
我不知道。
您永远不应该显式调用外部序列化函数。