直接reinterpret_cast写入二进制仅对标准布局类型安全,需static_assert验证;含std::string等非POD成员须手动序列化;注意内存对齐、跨平台字节序与类型宽度,推荐固定宽度类型和逐字段写入。

C++怎么做序列化 C++对象转二进制保存方法【实战】

std::ofstream 写裸内存前,先确认对象是标准布局

直接 reinterpret_cast(&obj) 写入二进制,只对标准布局类型(POD 或满足 std::is_standard_layout_v)安全。有虚函数、非公有继承、非公有成员、或含引用/非平凡构造/析构的类,这么干会读出乱码甚至崩溃。

手写序列化时,sizeof(T) 不等于实际存储长度

结构体有内存对齐,sizeof(MyStruct) 可能比字段字节和大很多。比如两个 char 中间插个 int,编译器可能补 3 字节空洞。直接按 sizeof 读写,跨平台或换编译器就错。

跨平台保存时,intfloat 的字节序和尺寸不能默认一致

x86 和 ARM 默认小端,但某些嵌入式平台是大端;int 在 Windows/MSVC 是 4 字节,但在某些旧嵌入式环境可能是 2 字节;float 虽然 IEEE 754 普遍支持,但 denormal 数处理可能不同。

想省事用 boost::serialization?先看清它的二进制档案不是“裸数据”

boost::archive::binary_oarchive 输出的是带元信息的二进制流,含类型名、版本号、指针偏移等,不是纯字段拼接。这意味着:

最易被忽略的一点:序列化不是存档,而是契约。一旦写入磁盘,字段增删、类型变更、甚至注释调整(影响 static_assert),都可能让老数据永远无法加载。别把序列化格式当成临时便利,它和 API 一样需要版本管理和向后兼容设计。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。