我正在使用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")
...

由于将传输字符串而不是整数,因此它将使用更多带宽,但这将解决您的问题。

有关更多信息,请引用thisthis

编辑:

这样编译就可以了:
#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/

10-11 18:01