0

0

C++如何使用protobuf_C++数据序列化与protobuf库实践

尼克

尼克

发布时间:2025-11-16 12:06:06

|

1076人浏览过

|

来源于php中文网

原创

Protobuf通过定义.proto文件并编译生成C++代码实现高效序列化,使用SerializeToOstream和ParseFromIstream完成数据读写,结合g++或CMake链接库即可在项目中集成。

c++如何使用protobuf_c++数据序列化与protobuf库实践

在C++项目中高效处理结构化数据,Protobuf(Protocol Buffers)是一个被广泛采用的序列化方案。它由Google开发,具备高性能、跨平台、跨语言等优势。下面介绍如何在C++中使用Protobuf进行数据序列化与反序列化,并结合实际步骤演示完整流程。

定义.proto文件描述数据结构

使用Protobuf的第一步是编写.proto文件,用于定义要序列化的消息格式。

例如,创建一个person.proto文件:

syntax = "proto3";
package tutorial;

message Person {
  string name = 1;
  int32 age = 2;
  string email = 3;
}

这个定义描述了一个包含姓名、年龄和邮箱的Person结构。字段后的数字是唯一标识符(tag),用于二进制编码

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

编译.proto文件生成C++代码

使用protoc编译器将.proto文件转换为C++类。

执行以下命令:

LongShot
LongShot

LongShot 是一款 AI 写作助手,可帮助您生成针对搜索引擎优化的内容博客。

下载
protoc --cpp_out=. person.proto

会生成两个文件:person.pb.ccperson.pb.h。这些文件包含了Person类的定义,提供了序列化、反序列化、访问字段等方法。

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

包含生成的头文件,在程序中创建并操作Person对象。

示例代码:

#include 
#include 
#include "person.pb.h"

int main() {
    // 设置日志输出(可选)
    google::protobuf::LogToStderr();

    tutorial::Person person;
    person.set_name("Alice");
    person.set_age(30);
    person.set_email("alice@example.com");

    // 序列化到文件
    std::ofstream output("person.data", std::ios::binary);
    if (!person.SerializeToOstream(&output)) {
        std::cerr << "序列化失败!" << std::endl;
        return -1;
    }
    output.close();

    // 从文件反序列化
    tutorial::Person restored_person;
    std::ifstream input("person.data", std::ios::binary);
    if (!restored_person.ParseFromIstream(&input)) {
        std::cerr << "反序列化失败!" << std::endl;
        return -1;
    }
    input.close();

    // 输出恢复的数据
    std::cout << "Name: " << restored_person.name() << std::endl;
    std::cout << "Age: " << restored_person.age() << std::endl;
    std::cout << "Email: " << restored_person.email() << std::endl;

    return 0;
}

编译与链接Protobuf库

编译上述代码需要链接Protobuf库。假设使用g++,命令如下:

g++ -o person_example person.pb.cc main.cpp -lprotobuf

确保系统已安装libprotobuf-dev(Linux)或正确配置了Protobuf的头文件与库路径(Windows/macOS)。若使用CMake,可添加:

find_package(Protobuf REQUIRED)
target_link_libraries(your_target ${Protobuf_LIBRARIES})

基本上就这些。只要定义好结构、生成代码、调用SerializeToOstream和ParseFromIstream,就能实现高效的C++数据序列化。Protobuf还支持嵌套消息、repeated字段、默认值和兼容性升级,适合复杂场景下的通信与存储需求。

相关专题

更多
mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

179

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

272

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

251

2025.06.11

c++标识符介绍
c++标识符介绍

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

121

2025.08.07

treenode的用法
treenode的用法

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

529

2023.12.01

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

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

7

2025.12.22

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

516

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1051

2023.07.27

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

62

2025.12.31

热门下载

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

精品课程

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

共94课时 | 5.7万人学习

C 教程
C 教程

共75课时 | 3.8万人学习

C++教程
C++教程

共115课时 | 10.6万人学习

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

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