如何查看开源项目对应的Protobuf版本,并安装指定版本的Protobuf

Protocol Buffers(简称 Protobuf)是由 Google 开发的一种语言中立、平台中立、可扩展的序列化格式。它用于结构化数据的序列化(也称为“编组”或“消息打包”),可以看作是一种高效的二进制数据格式,类似于 JSON 或 XML,但比它们更紧凑、更高效。

核心概念

  1. .proto 文件:

    • 这是定义数据结构的文件,你在其中使用 Protobuf 的语法来定义数据的结构、字段类型和消息格式。

    • 例如:

      syntax = "proto3";
      
      message Person {
        string name = 1;
        int32 id = 2;
        string email = 3;
      }
    • 这段代码定义了一个 Person 消息类型,它包含 nameidemail 三个字段。

  2. protoc 编译器:

    • protoc 是 Protobuf 的编译器工具。它可以将 .proto 文件编译成各种编程语言(如 C++、Java、Python 等)的源代码文件。

    • 这些源代码文件包含用于序列化、反序列化和操作 Protobuf 消息的代码。

  3. 序列化和反序列化:

    • 序列化 是将数据结构(如上面的 Person 消息)转换为一种紧凑的二进制格式以便传输或存储。

    • 反序列化 是将紧凑的二进制格式数据还原为原始的数据结构。

  4. 跨平台和语言中立:

    • Protobuf 支持多种编程语言(如 C++、Java、Python、Go 等)和平台,这使得它在分布式系统、网络通信、数据存储等场景中非常有用。

Protobuf 的优点

  1. 高效性:

    • Protobuf 使用二进制格式存储和传输数据,比 JSON 和 XML 更紧凑,占用更少的空间,并且序列化和反序列化速度更快。

  2. 可扩展性:

    • 你可以在不破坏现有代码的情况下添加新字段。这使得 Protobuf 在需要向后兼容的场景中非常有用。

  3. 跨语言支持:

    • Protobuf 提供了多种语言的支持,适合跨平台和跨语言的系统。

  4. 严格的类型检查:

    • 与 JSON 和 XML 不同,Protobuf 提供了强类型的定义,减少了数据解析和处理时的错误。

典型应用场景

  1. 网络通信:

    • 用于在分布式系统中传输数据,比如在微服务之间交换数据。

  2. 数据存储:

    • 用于高效地存储结构化数据。

  3. 配置管理:

    • 用于在应用程序中保存和读取配置数据。

  4. 远程过程调用(RPC):

    • 配合 gRPC(Google 的开源 RPC 框架)使用,Protobuf 被用作定义接口和消息格式的协议。

学习一个使用到Protobuf的开源项目时,可能会因为Protobuf版本错误等原因无法运行这个项目。

可以在项目中找到.pb文件,文件开头会指明使用的版本号

如上图所示项目中Protobuf版本为3.11.0

确定版本后便可按照Protobuf:安装指定版本 | AhaKnow中的方法安装指定的Protobuf版本。

注意在git clone时可能会因为Ubuntu无法上外网而git失败,这时可以按https://www.zhihu.com/question/495148700中的方法使你虚拟机能够科学上网,从而git成功。

如果你安装的Protobuf的位置并不在项目的cmakelist.txt文件所指定的路径范围内,你还需要手动添加Protobuf的头文件和和执行文件路径,使编译时能找到Protobuf相关文件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值