我正在使用boost来序列化和反序列化某些类
像这样:
boost::archive::xml_oarchive xmlArchive(oStringStream);
xmlArchive.register_type(static_cast<BaseMessage *>(NULL));
xmlArchive.register_type(static_cast<IncomingTradeMessage *>(NULL));
xmlArchive.register_type(static_cast<InternalRequestInfo *>(NULL));
xmlArchive.register_type(static_cast<InternalTradeTransInfo *>(NULL));
const BaseMessage* myMessage =message;
xmlArchive << make_nvp("Message", myMessage);
现在我的故事根据使用的顺序得到了一个class_id,我不想要那个,我想控制Class_id的
所以我可以做类似的事情
BOOST_SET_CLASS_ID(1234, BaseMessage);
并且我的项目BaseMessage中的每个地方的class_id为1234。
我该怎么做
最佳答案
您不能使用BOOST_CLASS_EXPORT_GUID
或类似代码吗?即
BOOST_CLASS_EXPORT_GUID(IncomingTradeMessage, "IncomingTradeMessage")
...
由于将传输字符串而不是整数,因此它将使用更多带宽,但这将解决您的问题。
有关更多信息,请引用this和this。
编辑:
这样编译就可以了:
#include <fstream>
#include <boost/serialization/export.hpp>
#include <boost/archive/text_oarchive.hpp>
class Foo {
friend class boost::serialization::access;
template<class Archive>
void serialize(Archive & ar, const unsigned int version)
{
ar & dummy1;
}
int dummy1;
public:
virtual ~Foo() {}
};
class Bar : public Foo {
friend class boost::serialization::access;
template<class Archive>
void serialize(Archive & ar, const unsigned int version)
{
// serialize base class information
ar & boost::serialization::base_object<Foo>(*this);
ar & dummy2;
}
int dummy2;
};
BOOST_CLASS_EXPORT_GUID(Foo, "Foo")
BOOST_CLASS_EXPORT_GUID(Bar, "Bar")
int main(int argc, char *argv[]) {
std::ofstream ofs("filename");
boost::archive::text_oarchive oa(ofs);
Foo *f = new Bar;
oa << f;
return 0;
}
关于c++ - C++ boost::serialization为类设置固定的class_id,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/3148794/