主流方案是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++ 老炮儿的贴心工具——不复杂但容易忽略细节,动手试一次就清楚了。
以上就是c++++如何序列化和反序列化对象_c++ Protobuf与Boost.Serialization【教程】的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1489367.html
微信扫一扫
支付宝扫一扫