增强使用结构中包含的 typedef 定义的本机类型的序列化
我有一个包含各种类型和枚举的 MyFile.hpp 头文件.我如何对给定的示例代码进行序列化/反序列化.
I have a MyFile.hpp header file which contains various types and enums. How do i do serialization/ desrialization of given example code.
//MyFile.hpp
//MyFile.hpp
namespace A {
namespace B {
typedef std::string MyString;
typedef std::map<std::string,std::string> my_type;
typedef bool result;
struct MyTimer
{
int time;
private :
friend class boost::serialization::access;
template<class Archive>
void serialize(Archive &ar, const unsigned int version)
{
ar & time;
}
};
enum MODE
{
Sleep=1,
HybridSleep,
Hybernate
}
}
}
我需要在对应的 MyFile.cpp 中实现,但不知道我该怎么做.
I need to do implementation in corresponding MyFile.cpp but don't know how do i go ahead.
谢谢,
推荐答案
地图、字符串等可以通过包含相关标题来序列化:
Maps, strings etc. can just be serialized by including the relevant header:
#include <boost/serialization/map.hpp>
#include <boost/serialization/string.hpp>
枚举 算作原始类型:一个>
当且仅当以下条件之一为真时,类型 T 是可序列化的:
A type T is Serializable if and only if one of the following is true:
它是一种原始类型.
it is a primitive type.
原始类型是指 C++ 内置类型,仅是 C++ 内置类型.算术(包括字符)、bool、enum 是原始类型.在下面的序列化特征中,我们为不同的目的以不同的方式定义了一个原始"实现级别.这可能是混淆的根源.
By primitive type we mean a C++ built-in type and ONLY a C++ built-in type. Arithmetic (including characters), bool, enum are primitive types. Below in serialization traits, we define a "primitive" implementation level in a different way for a different purpose. This can be a source of confusion.
- 一个类成员函数序列化
- 一个全局函数序列化
对于更棘手的情况,有 BOOST_STRONG_TYPEDEF
(参见 文档序列化包装器")
For more tricky cases there is BOOST_STRONG_TYPEDEF
(see documentation "Serialization Wrappers")
相关文章