主流方案是Protobuf和Boost.Serialization:Protobuf跨语言高性能,需.proto定义+代码生成;Boost.Serialization专注C++生态,直接序列化复杂对象。选Protobuf用于多语言互通或RPC,Boost.Serialization适合纯C++项目快速持久化。

在 C++ 中序列化和反序列化对象,主流方案是 Protocol Buffers(Protobuf) 和 Boost.Serialization。两者定位不同:Protobuf 侧重跨语言、高性能、网络传输;Boost.Serialization 更适合 C++ 单一生态内的对象持久化或进程间传递,支持指针、继承、多态等复杂结构。
Protobuf:定义 Schema + 自动生成代码
Protobuf 不直接操作 C++ 对象,而是先用 .proto 文件定义数据结构,再用 protoc 工具生成 C++ 类。这些类自带 SerializeToString() 和 ParseFromString() 方法。
- 安装 protoc 编译器和 libprotobuf-dev(Linux)或通过 vcpkg/conan 安装
- 写 hello.proto:syntax = "proto3"; message Person { string name = 1; int32 age = 2; repeated string email = 3; }
- 生成代码:protoc --cpp_out=. hello.proto → 得到 hello.pb.h/.cc
- 使用示例:Person p; p.set_name("Alice"); p.set_age(30); std::string data; p.SerializeToString(&data); // 序列化
Person p2; p2.ParseFromString(data); // 反序列化
注意:必须严格匹配 proto 版本与运行时库版本;字段需有唯一 tag 编号;不支持直接序列化裸指针或非 POD 类型成员(需手动处理)。
Boost.Serialization:直接操作对象,语法简洁
Boost.Serialization 基于模板和宏,对已有类只需添加 serialize() 成员函数(或友元),即可实现深度序列化,天然支持 STL 容器、智能指针、继承关系。
立即学习“C++免费学习笔记(深入)”;
- 需链接 -lboost_serialization,头文件包含 #include
等 - 类中声明 serialize:template
void serialize(Archive& ar, const unsigned int version) { ar & name & age & emails; } - 序列化到文件:std::ofstream ofs("person.txt"); boost::archive::text_oarchive oa(ofs); oa
- 反序列化:std::ifstream ifs("person.txt"); boost::archive::text_iarchive ia(ifs); ia >> p2;
支持 text、binary、xml 归档格式;binary 最小最快;text 可读但体积大;需注意版本兼容性(version 参数可用来做迁移适配)。
选哪个?看场景
- 要和 Java/Python/Go 互通,或做 RPC 接口 → 选 Protobuf
- 纯 C++ 项目,想快速存/读配置、缓存对象图、调试导出状态 → Boost.Serialization 更自然
- 追求极致性能且数据结构稳定 → Protobuf binary 通常更快更省空间
- 已有复杂类带 shared_ptr、虚函数、多重继承 → Boost.Serialization 开箱即用,Protobuf 需手动映射
基本上就这些。Protobuf 是工业级通信标准,Boost.Serialization 是 C++ 老炮儿的贴心工具——不复杂但容易忽略细节,动手试一次就清楚了。











