尝试序列化这个简单的类:
class Data
{
public:
Data();
Data(boost::uuids::uuid id);
Data(const Data&) = delete;
Data& operator=(const Data&) = delete;
inline boost::uuids::uuid getGuid() { return guid; }
template <class Archive>
void serialize(Archive & ar)
{
ar(guid);
}
private:
boost::uuids::uuid guid;
};
但我收到此错误消息
error C2338: Trying to serialize an unserializable type with an output archive.
指向uuid。启用此功能的boost序列化方法是添加
#include <boost/uuid/uuid_serialize.hpp>
但这不适用于谷物开箱即用。谷歌文件说
grain档案可以在std :: ostream或std :: istream对象上运行。
所以我尝试添加已定义但没有运气的标题
#include <boost/uuid/uuid_io.hpp>
答案 0 :(得分:4)
这适用于谷物JSON档案。我还在评论中包含了为二进制存档执行此操作的方法。
#ifndef CEREAL_TYPES_BOOST_UUID_
#define CEREAL_TYPES_BOOST_UUID_
#include <boost/uuid/uuid.hpp>
#include <boost/uuid/uuid_io.hpp>
#include <boost/lexical_cast.hpp>
namespace cereal
{
template <class Archive> inline
void save(Archive& ar, boost::uuids::uuid const& uuid)
{
std::string val = boost::lexical_cast<std::string>(uuid);
ar(val);
// Other approach, probably better for binary
//ar(make_size_tag(static_cast<size_type>(uuid.size())));
//for (auto it = uuid.begin(), end = uuid.end(); it != end; ++it)
// ar(*it);
}
template <class Archive> inline
void load(Archive& ar, boost::uuids::uuid& uuid)
{
std::string val;
ar(val);
uuid = boost::lexical_cast<boost::uuids::uuid>(val);
// Other approach, probably better for binary
//size_type size;
//ar(make_size_tag(size));
//for (auto it = uuid.begin(), end = uuid.end(); it != end; ++it) {
// uint8_t val;
// ar(val);
// *it = val;
//}
}
} // namespace cereal
#endif // CEREAL_TYPES_BOOST_UUID_
答案 1 :(得分:1)
事实
grain档案可以在std :: ostream或std :: istream对象上运行。
(根本不)暗示它使用IO流操作符(&gt;&gt;,&lt;&lt;)。那只是存档实现。
你必须实现免费功能serialize
让谷歌知道你的类型。您应该能够重用uuid_serialize.hpp
中显示的实现。你有可能只是
boost::uuids::uuid
是POD数据类型)