0

0

C++怎么用Protobuf进行数据序列化_C++结构化数据通信与序列化方法

穿越時空

穿越時空

发布时间:2025-10-27 22:22:01

|

718人浏览过

|

来源于php中文网

原创

首先定义.proto文件描述数据结构,再用protoc生成C++代码,接着在程序中包含头文件并调用SerializeToOstream或ParseFromIstream进行序列化与反序列化,最后确保项目正确链接libprotobuf库并保持.proto与代码同步。

c++怎么用protobuf进行数据序列化_c++结构化数据通信与序列化方法

在C++中使用Protobuf进行数据序列化是处理结构化数据通信的高效方式,尤其适用于网络传输和持久化存储。Google Protocol Buffers(简称Protobuf)通过定义数据结构的.proto文件,生成对应语言的代码,实现跨平台、跨语言的数据交换。以下是具体使用方法。

定义.proto消息格式

要使用Protobuf,第一步是编写.proto文件来描述需要序列化的数据结构。

示例:person.proto

syntax = "proto2";
package tutorial;

message Person {
  required string name = 1;
  required int32 id = 2;
  optional string email = 3;
}

上述定义了一个包含姓名、ID和邮箱的Person消息类型。字段前的required、optional表示是否必须赋值(proto3中已简化,默认均为optional)。

生成C++代码

使用protoc编译器将.proto文件转换为C++头文件和源文件:

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

命令:
protoc --cpp_out=. person.proto

执行后会生成person.pb.h和person.pb.cc。这些文件包含了Person类的定义,提供了序列化、反序列化、访问字段等方法。

Pixlr
Pixlr

Pixlr是一款2008年推出的在线图片编辑和AI图片处理工具,目前已推出AI 图像生成器、AI 生成填充、AI 删除背景、AI 删除对象和 AI 图像扩展等现代 AI 工具。

下载

在C++中序列化与反序列化

包含生成的头文件后,即可在C++代码中创建对象并进行序列化操作。

序列化示例:

#include "person.pb.h"
#include stream>

int main() {
  tutorial::Person person;
  person.set_name("Alice");
  person.set_id(1234);
  person.set_email("alice@example.com");

  std::ofstream output("person.bin", std::ios::binary);
  person.SerializeToOstream(&output);
  output.close();
  return 0;
}

反序列化示例:

#include "person.pb.h"
#include

int main() {
  tutorial::Person person;
  std::ifstream input("person.bin", std::ios::binary);
  person.ParseFromIstream(&input);
  input.close();

  std::cout   std::cout   if (person.has_email()) {
    std::cout   }
  return 0;
}

集成到项目中的注意事项

使用Protobuf需确保项目正确链接libprotobuf库。常见构建方式包括:

  • 使用CMake时添加 find_package(Protobuf REQUIRED) 和 target_link_libraries(your_target ${PROTOBUF_LIBRARIES})
  • 编译时手动链接:g++ main.cpp person.pb.cc -lprotobuf
  • 保持.proto文件与生成代码同步,每次修改后重新运行protoc
  • 推荐使用proto3语法以获得更简洁的API和默认值支持

基本上就这些。Protobuf在C++中提供了一套稳定高效的序列化机制,配合清晰的接口和良好的性能,非常适合用于服务间通信或配置文件存储。只要定义好结构,其余工作由工具链自动完成,开发效率高,出错概率低。

相关专题

更多
string转int
string转int

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

311

2023.08.02

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

698

2023.08.22

string转int
string转int

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

311

2023.08.02

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

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

510

2024.08.29

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

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

46

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

174

2025.08.29

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

529

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

1

2025.12.22

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

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

精品课程

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

共32课时 | 2.9万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

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

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