您的位置:首页 >C++对象序列化方法及二进制保存实战
发布于2026-03-06 阅读(0)
扫一扫,手机访问
直接reinterpret_cast写入二进制仅对标准布局类型安全,需static_assert验证;含std::string等非POD成员须手动序列化;注意内存对齐、跨平台字节序与类型宽度,推荐固定宽度类型和逐字段写入。

std::ofstream 写裸内存前,先确认对象是标准布局直接 reinterpret_cast 写入二进制,只对标准布局类型(POD 或满足 std::is_standard_layout_v)安全。有虚函数、非公有继承、非公有成员、或含引用/非平凡构造/析构的类,这么干会读出乱码甚至崩溃。
static_assert(std::is_standard_layout_v, "not standard layout"); std::string 成员就立刻失效——它内部指针在反序列化后指向无效地址std::string,得手动序列化其 .data() 和 .size(),再单独写字符串内容sizeof(T) 不等于实际存储长度结构体有内存对齐,sizeof(MyStruct) 可能比字段字节和大很多。比如两个 char 中间插个 int,编译器可能补 3 字节空洞。直接按 sizeof 读写,跨平台或换编译器就错。
#pragma pack(1) 强制紧凑对齐(注意性能损耗),或用 alignas(1) 显式声明out.write(reinterpret_cast(&x.a), sizeof(x.a)); int 和 float 的字节序和尺寸不能默认一致x86 和 ARM 默认小端,但某些嵌入式平台是大端;int 在 Windows/MSVC 是 4 字节,但在某些旧嵌入式环境可能是 2 字节;float 虽然 IEEE 754 普遍支持,但 denormal 数处理可能不同。
int32_t、uint8_t、float32_t(需 <cstdint> 和 <cfenv>)htons()/htonl(),读后用 ntohs()/ntohl();C++23 起可用 std::byteswapstd::endian::native == std::endian::big 现场判断boost::serialization?先看清它的二进制档案不是“裸数据”boost::archive::binary_oarchive 输出的是带元信息的二进制流,含类型名、版本号、指针偏移等,不是纯字段拼接。这意味着:
xxd 直接看字段值BOOST_CLASS_VERSION)ar & BOOST_SERIALIZATION_NVP(obj); 前加 ar.disable_tracking<MyType>();最易被忽略的一点:序列化不是存档,而是契约。一旦写入磁盘,字段增删、类型变更、甚至注释调整(影响 static_assert),都可能让老数据永远无法加载。别把序列化格式当成临时便利,它和 API 一样需要版本管理和向后兼容设计。
上一篇:浏览器网页转PDF保存教程
下一篇:Go语言Map合并方法与技巧
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9