0

0

c++如何将结构体序列化为二进制_c++结构体转char流【实战】

尼克

尼克

发布时间:2026-01-24 13:07:02

|

864人浏览过

|

来源于php中文网

原创

只有POD结构体才能安全memcpy;需满足无虚函数、无非静态成员函数、无用户定义构造/析构/赋值、所有成员也均为POD,否则须手写序列化逻辑。

c++如何将结构体序列化为二进制_c++结构体转char流【实战】

直接 memcpy 可能出问题,先确认结构体是否满足 POD

不是所有结构体都能安全 memcpy 成二进制流。C++ 要求类型是 POD(Plain Old Data):不能有虚函数、非静态成员函数、私有/保护非静态数据成员、用户定义构造/析构/赋值函数,且所有成员本身也必须是 POD。

常见踩坑点:

  • 结构体里加了 std::stringstd::vector → 直接 memcpy 会把指针地址写进去,反序列化后读的是野指针
  • 用了 #pragma pack(1) 但没在接收端用同样对齐 → 字节序和偏移错乱
  • 结构体含浮点数或指针,在不同平台(如 x86 vs ARM)上可能因 ABI 差异导致位宽或字节序不一致

简单 POD 结构体:用 reinterpret_cast + memcpy 最快

若确认结构体是 POD(比如纯 C 风格的 struct Packet { uint32_t len; uint16_t id; char data[64]; };),可直接转为 char* 流:

Packet pkt = {1024, 123, "hello"};
char buf[sizeof(Packet)];
memcpy(buf, &pkt, sizeof(Packet));
// 发送 buf,或存入文件

反序列化同理:

立即学习C++免费学习笔记(深入)”;

Packet* p = reinterpret_cast<Packet*>(buf);
// 注意:buf 生命周期必须长于 p 的使用期;不要用 static_cast 替代 reinterpret_cast

关键提醒:

阿里妈妈·创意中心
阿里妈妈·创意中心

阿里妈妈营销创意中心

下载
  • 发送前确保 sizeof(Packet) 在收发两端完全一致(检查编译器、打包指令、对齐方式)
  • 避免跨平台直接传浮点字段——float 在 IEEE754 下虽通用,但某些嵌入式平台不保证
  • 别对含 bit-field 的结构体这么做,位域布局无标准保证

含 STL 容器或非 POD 成员?必须手写序列化逻辑

例如结构体带 std::string namestd::vector<int> ids,就不能整体拷贝。得拆开处理:

  • 先写固定头:如 uint32_t name_len,再写 name.data() 的原始字节
  • 再写 uint32_t ids_size,然后逐个写 ids[i](注意 endianness)
  • 接收端严格按相同顺序读:先读长度,再 malloc/resize,再读数据块

示例片段(简化版):

void serialize(const MyStruct& s, std::vector<char>& out) {
    uint32_t len = htonl(static_cast<uint32_t>(s.name.size())); // 网络序
    out.insert(out.end(), reinterpret_cast<const char*>(&len), 
               reinterpret_cast<const char*>(&len) + sizeof(len));
    out.insert(out.end(), s.name.begin(), s.name.end());
}

注意:htonl / ntohl 仅对整数有效,且只解决字节序,不解决大小端对齐差异(如 long 在 Windows 和 Linux 可能是 4 或 8 字节)。

跨语言或长期存储?别手撸,用 Protocol Buffers 或 flatbuffers

如果结构体要被 Python/Java 读取,或需向前兼容(比如新增字段不影响旧版本解析),硬编码二进制格式很快失控。这时候:

  • protobuf:定义 .proto 文件,生成 C++ 类,自带 SerializeToArrayParseFromArray
  • flatbuffers:零拷贝、无需解析步骤,适合高频低延迟场景,但要求结构体字段全为 POD 或 flatbuffers 内置类型
  • 避免用 boost::serialization:它依赖运行时类型信息和 operator<< 重载,生成的二进制不跨语言、不易调试

真正容易被忽略的一点:即使你控制全部代码,只要未来可能加日志回放、网络协议升级、或导出数据给数据分析脚本,二进制格式就必须带 magic number + version 字段 —— 否则某天 sizeof(MyStruct) 变了,老数据就永远读不出来了。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1051

2023.08.02

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

595

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

108

2025.10.23

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

490

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

202

2025.07.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1051

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

615

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

335

2025.08.29

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.7万人学习

Git 教程
Git 教程

共21课时 | 4.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号