我遇到以下问题..
我有一个名为A.h的文件和一个文件B.h.每个包含一些像这样的结构:(两个类中的结构是不同的)
struct Base
{
friend class access;
template <typename Archive>
void serialize(Archive& ar,const unsigned int version)
{
ar & fieldLength;
ar & fieldMD;
ar & fieldTime_Stamp;
}
public:
unsigned int fieldLength;
unsigned int fieldMD;
unsigned int fieldTime_Stamp;
virtual void f(){} //to be polymorphic the struct
};
struct Derived:public Base
{
...
}
所以我以经典的方式序列化结构:
....
std::ostringstream archive_stream;
boost::archive::text_oarchive archive(archive_stream);
archive.register_type(static_cast<Derived*>(NULL))
archive <<p; // where p is a pointer to Base
现在问题...... 在反序列化方面,我遵循相同的(逆)程序...如果我单独反序列化Ah中的结构(不包括在项目Bh中)和Bh中的结构(不包括在项目中)所有工作...... .but如果我在项目中包含两个类,则反序列化适用于一个类,但会在“archive&gt;&gt; m;”指令中抛出“Stream error exception”。对于另一个......这似乎是注册类中的冲突或类似的事情...... 有什么想法吗?谢谢......
答案 0 :(得分:2)
您是否已在派生类序列化函数中序列化基础数据?
ar & boost::serialization::make_nvp( "base", boost::serialization::base_object< Base >( *this ) );
我不知道这是否会有所帮助,但我使用
BOOST_CLASS_IMPLEMENTATION(x, boost::serialization::object_serializable);
BOOST_CLASS_TRACKING(x, boost::serialization::track_never)
将类注册为serialiseable。希望有所帮助:3