Protobuf 为啥比 JSON、XML 牛?

今天,我带大家更深层次的认识认识 Protobuf,如果你对 Protobuf 的用法还不熟悉,直接前往:
developers.google.com/protocol-bu…。

当对 Protobuf 有了基本的认识后,就会明白了 Protobuf 序列化的数据会比 JSON、XML 传输效率更高。

那为啥会高呢?本篇就带着这个问题一探究竟。

看表面

对于 JSON、XML,为了便于数据传输时的可阅读性,会保留数据的结构化信息,举个 JSON 例子,如下:

{
  "name": "laomiao",
  "age": 18
}
复制代码

当发送该信息时,接受方收到后就会明白,这是个 “key/value” 形式的数据,并且"name" 后是姓名,"age" 后是年龄。

那如何压缩该数据呢?

我们可以删除 “花括号”、“name”、“age” 以及其它的 “冒号”、“逗号”、“引号” 等结构数据。

laomiao18
复制代码

那这样删除了,接收方怎么知道,哪个是姓名?哪个是年龄?

删除 ”结构“

只需要发送方和接收方都保留这份数据的 ”结构“ 就行,发送方只发送数据,接收方接收到数据后,根据本地保留的 ”结构“ 去解析数据就 OK。

假设,该 "结构" 如下,这不是真实存在的,只是为了方便给大家描述。

{
  name string 7
  age int 1
}
复制代码

通过该 ”结构“ 就可以知道:

  • name 数据在 age 数据之前。
  • name 数据类型为 string,age 数据类型为 int。
  • name 数据字节长度为 7,age 数据字节长度为 1。

接收方只需要拿着这份 ”结构“ 就知道了 "laomiao18" 数据如何解析。

自描述

但这样还是有这些问题:

  1. name 数据如果超过 7 个字节怎么办?
  2. age 数据超过 1
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JsonFormat 是 Google 提供的一个 Java 库,用于将 JSON 格式的数据转换为 Protocol Buffers(protobuf)格式的数据,以及将 protobuf 格式的数据转换为 JSON 格式的数据。 要使用 JsonFormat 进行转换,首先需要在项目中引入相应的依赖。在 Maven 项目中,可以在 pom.xml 文件中添加以下依赖: ```xml <dependency> <groupId>com.google.protobuf</groupId> <artifactId>protobuf-java</artifactId> <version>3.17.3</version> </dependency> <dependency> <groupId>com.google.protobuf</groupId> <artifactId>protobuf-java-util</artifactId> <version>3.17.3</version> </dependency> ``` 接下来,我们可以使用 JsonFormat 进行转换。假设我们有一个 protobuf 的消息类型为 `Person`,对应的 JSON 格式如下: ```json { "name": "John", "age": 25, "email": "john@example.com" } ``` 首先,我们需要定义一个 `Person` 对象,并使用 `JsonFormat.parser()` 方法将 JSON 数据解析为 protobuf 对象: ```java import com.google.protobuf.util.JsonFormat; // 定义 Person 对象 Person.Builder personBuilder = Person.newBuilder(); // 将 JSON 数据解析为 protobuf 对象 JsonFormat.parser().merge(jsonString, personBuilder); Person person = personBuilder.build(); ``` 其中,`jsonString` 是包含 JSON 数据的字符串。 接下来,如果我们想将 protobuf 对象转换为 JSON 格式,可以使用 `JsonFormat.printer()` 方法: ```java import com.google.protobuf.util.JsonFormat; // 将 protobuf 对象转换为 JSON 格式 String jsonString = JsonFormat.printer().print(person); ``` 这样,我们就可以使用 JsonFormat 进行 JSON 格式和 protobuf 格式之间的转换了。 需要注意的是,JsonFormat 在转换过程中会根据 protobuf 的定义进行字段的映射,因此需要保证 protobuf 的定义与 JSON 数据的字段名称和类型相匹配。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值