首页 > 后端开发 > C++ > 正文

c++中如何使用Protobuf进行数据序列化和反序列化【跨语言通信】

尼克
发布: 2025-12-18 11:53:02
原创
913人浏览过
C++中使用Protobuf需定义.proto文件、用protoc生成C++代码,再通过SerializeToString序列化和ParseFromString反序列化;须检查返回值确保字段已设且数据有效。

c++中如何使用protobuf进行数据序列化和反序列化【跨语言通信】

在 C++ 中使用 Protocol Buffers(Protobuf)做数据序列化和反序列化,核心是定义 .proto 文件、生成 C++ 代码、再用生成的类进行编解码。它天然支持跨语言通信,只要各端用同一份 .proto 定义,就能互相解析。

定义并编译 .proto 文件

先写一个描述数据结构的 person.proto

syntax = "proto3";
message Person {
  string name = 1;
  int32 id = 2;
  string email = 3;
}
登录后复制

用 Protobuf 编译器生成 C++ 代码:

protoc --cpp_out=. person.proto
登录后复制

会生成 person.pb.hperson.pb.cc,需在项目中包含并链接 libprotobuf

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

Fotor AI Image Upscaler
Fotor AI Image Upscaler

Fotor推出的AI图片放大工具

Fotor AI Image Upscaler 73
查看详情 Fotor AI Image Upscaler

序列化:将对象转为二进制字节

创建对象 → 填充字段 → 调用 SerializeToString()SerializeToArray()

  • 确保所有 required 字段(proto2)或非 optional 字段(proto3)已设置,否则序列化失败
  • 推荐用 SerializeToString(std::string* output),避免手动管理内存
  • 返回 bool,务必检查是否成功
Person person;
person.set_name("Alice");
person.set_id(123);
person.set_email("alice@example.com");
<p>std::string data;
if (!person.SerializeToString(&data)) {
// 序列化失败,通常因字段未设或内存不足
}
登录后复制

反序列化:从字节流还原对象

ParseFromString()ParseFromArray(),注意初始化和错误处理:

  • 目标对象无需预先构造完整数据,调用前可为默认构造
  • 若字节流损坏、字段编号错或类型不匹配,解析会失败,返回 false
  • proto3 中未出现的字段会被忽略;proto2 中缺失 required 字段会导致解析失败
Person parsed;
if (parsed.ParseFromString(data)) {
  std::cout << parsed.name() << ", " << parsed.id() << "\n";
} else {
  // 解析失败,可能是数据被篡改、版本不兼容或传输截断
}
登录后复制

跨语言通信的关键实践

要保证不同语言(如 Python/Java/Go)之间互通,必须遵守以下约定:

  • 所有服务共用同一套 .proto 文件,并统一使用 proto3(推荐,更简洁且默认兼容性好)
  • 字段编号固定不变,新增字段只能加在末尾,且必须设为 optional(proto3 中所有字段默认可选)
  • 避免使用浮点数做精确比较,不同语言底层实现可能有细微差异
  • 传输时建议带上版本标识或消息类型 ID(例如用一个 enum 区分不同 message),便于服务端路由和兼容升级

以上就是c++++中如何使用Protobuf进行数据序列化和反序列化【跨语言通信】的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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