C++中使用cereal库可便捷实现对象序列化,该头文件库支持JSON、XML和二进制格式。1. 无需安装,直接包含头文件即可使用;2. 通过定义serialize函数模板并配合CEREAL_NVP宏实现成员变量的序列化;3. 利用输出归档(如JSONOutputArchive)将对象保存至文件;4. 使用输入归档(如JSONInputArchive)从文件反序列化恢复对象;5. 原生支持vector、map等STL容器,私有成员可通过友元和宏处理。整个过程简洁直观,适合现代C++项目快速集成。
C++中使用cereal库进行序列化非常方便,它是一个现代化、轻量级、仅头文件的C++序列化库,支持将对象保存为JSON、XML、二进制等格式。由于是头文件形式,无需编译安装,只需包含相应头文件即可使用。
cereal是纯头文件库,可以直接从GitHub下载并放入项目include目录:
#include
#include
#include
要让一个类支持序列化,需在其内部或外部定义serialize函数模板,声明其如何读写成员变量。
示例:序列化一个简单的Person类
class Person {
public:
std::string name;
int age;
// 序列化函数
template
void serialize(Archive& ar) {
ar(CEREAL_NVP(name), CEREAL_NVP(age)); // NVP添加命名信息(用于JSON/XML)
}
};
然后可以将其保存为JSON文件:
#include#include void save() { Person p{"Alice", 30}; std::ofstream os("person.json"); cereal::JSONOutputArchive archive(os); archive(CEREAL_NVP(p)); }
反序列化过程与序列化类似,只需创建输入归档对象并从中加载数据。
void load() {
Person p;
std::ifstream is("person.json");
cereal::JSONInputA
rchive archive(is);
archive(p); // 或 archive(CEREAL_NVP(p));
std::cout << "Name: " << p.name << ", Age: " << p.age << std::endl;
}
cereal天然支持STL常见类型,如vector、map、string、array等,无需额外定义。
例如序列化一个学生列表:
std::vectorstudents = {{"Bob", 25}, {"Charlie", 28}}; { std::ofstream os("students.json"); cereal::JSONOutputArchive ar(os); ar(CEREAL_NVP(students)); }
读取时也一样直接:
std::vectorloaded_students; std::ifstream is("students.json"); cereal::JSONInputArchive ar(is); ar(loaded_students);
基本上就这些。只要包含对应头文件,实现serialize方法,就能轻松完成对象持久化。不复杂但容易忽略的是确保每个成员都被正确注册到归档中。对于私有成员,可使用CEREAL_SERIALIZE_FUNCTION_NAME宏配合友元方式处理。cereal的设计简洁直观,适合现代C++项目快速集成序列化功能。