C++中使用Protobuf需定义.proto文件、用protoc生成C++代码,再通过SerializeToString序列化和ParseFromString反序列化;须检查返回值确保字段已设且数据有效。

在 C++ 中使用 Protocol Buffers(Protobuf)做数据序列化和反序列化,核心是定义 .proto 文件、生成 C++ 代码、再用生成的类进行编解码。它天然支持跨语言通信,只要各端用同一份 .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.h 和 person.pb.cc,需在项目中包含并链接 libprotobuf。
立即学习“C++免费学习笔记(深入)”;
创建对象 → 填充字段 → 调用 SerializeToString() 或 SerializeToArray():
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
Person parsed;
if (parsed.ParseFromString(data)) {
std::cout << parsed.name() << ", " << parsed.id() << "\n";
} else {
// 解析失败,可能是数据被篡改、版本不兼容或传输截断
}要保证不同语言(如 Python/Java/Go)之间互通,必须遵守以下约定:
.proto 文件,并统一使用 proto3(推荐,更简洁且默认兼容性好)optional(proto3 中所有字段默认可选)以上就是c++++中如何使用Protobuf进行数据序列化和反序列化【跨语言通信】的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号