Protobuf3的全面剖析

一、Protobuf3编码规则

Protobuf3采用的是二进制编码,它对数据进行了压缩并使数据更加紧凑。每个字段都拥有自己的唯一标识符、数据类型和标识位。使用不同的标识位可以标识出不同的数据类型,例如:WireType.Varint(变长整型)、WireType.Fixed32、WireType.Fixed64等。

在序列化的时候,Protobuf将会按照定义的顺序依次写入每一个字段的数据。在反序列化的时候,Protobuf将会按照定义的顺序依次读取每一个字段的数据,并根据字段的标识位和数据类型将其解析出来。

下面是一个使用Protobuf3编码规则进行编码的示例代码:

syntax = "proto3";

message Person {
    int32 id = 1;
    string name = 2;
    bool is_active = 3;
}

二、Protobuf3不能设默认值

在 Protobuf 3 中,字段不能再有默认值了,如果不设置字段内容就不会序列化这个字段

默认值的设定方式是在 message 中的字段定义的时候通过 [default = 默认值] 来设置。

下面是一个无法设置默认值的示例代码:

syntax = "proto3";

message Person {
    int32 id;
    string name;
    bool is_active;
}

三、Protobuf3的JSON序列化

在 Protobuf 3 中提供了对 JSON 格式的支持,这使得 Protobuf 便于在 Web 开发中使用。

对于 Protobuf 消息的 JSON 编码,其所有整数类型皆作为数字类型编码,不会自动转换成字符串编码。

下面是一个将 Protobuf3 消息序列化为 JSON 格式的示例代码:

syntax = "proto3";

message Person {
    int32 id = 1;
    string name = 2;
    bool is_active = 3;
}

Person person = Person.newBuilder()
    .setId(1)
    .setName("John")
    .setIsActive(true)
    .build();

JsonFormat.Printer printer = JsonFormat.printer().includingDefaultValueFields();
String json = printer.print(person);
System.out.println(json);

四、Protobuf3的嵌套消息

在 Protobuf 3 中,可以在 message 中嵌套 message,这使得 Protobuf 支持更加复杂的数据结构。

下面是一个示例代码,定义了一个嵌套的 Address message:

syntax = "proto3";

message Address {
    string country = 1;
    string city = 2;
    string street = 3;
}

message Person {
    int32 id = 1;
    string name = 2;
    bool is_active = 3;
    Address address = 4;
}

Person person = Person.newBuilder()
    .setId(1)
    .setName("John")
    .setIsActive(true)
    .setAddress(Address.newBuilder()
        .setCountry("USA")
        .setCity("San Francisco")
        .setStreet("Mission St.")
        .build())
    .build();

原创文章,作者:XFPQ,如若转载,请注明出处:https://www.506064.com/n/134365.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
XFPQXFPQ
上一篇 2024-10-04 00:05
下一篇 2024-10-04 00:05

相关推荐

  • Python应用程序的全面指南

    Python是一种功能强大而简单易学的编程语言,适用于多种应用场景。本篇文章将从多个方面介绍Python如何应用于开发应用程序。 一、Web应用程序 目前,基于Python的Web…

    编程 2025-04-29
  • Python zscore函数全面解析

    本文将介绍什么是zscore函数,它在数据分析中的作用以及如何使用Python实现zscore函数,为读者提供全面的指导。 一、zscore函数的概念 zscore函数是一种用于标…

    编程 2025-04-29
  • 全面解读数据属性r/w

    数据属性r/w是指数据属性的可读/可写性,它在程序设计中扮演着非常重要的角色。下面我们从多个方面对数据属性r/w进行详细的阐述。 一、r/w的概念 数据属性r/w即指数据属性的可读…

    编程 2025-04-29
  • Python计算机程序代码全面介绍

    本文将从多个方面对Python计算机程序代码进行详细介绍,包括基础语法、数据类型、控制语句、函数、模块及面向对象编程等。 一、基础语法 Python是一种解释型、面向对象、动态数据…

    编程 2025-04-29
  • Matlab二值图像全面解析

    本文将全面介绍Matlab二值图像的相关知识,包括二值图像的基本原理、如何对二值图像进行处理、如何从二值图像中提取信息等等。通过本文的学习,你将能够掌握Matlab二值图像的基本操…

    编程 2025-04-28
  • 疯狂Python讲义的全面掌握与实践

    本文将从多个方面对疯狂Python讲义进行详细的阐述,帮助读者全面了解Python编程,掌握疯狂Python讲义的实现方法。 一、Python基础语法 Python基础语法是学习P…

    编程 2025-04-28
  • 全面解析Python中的Variable

    Variable是Python中常见的一个概念,是我们在编程中经常用到的一个变量类型。Python是一门强类型语言,即每个变量都有一个对应的类型,不能无限制地进行类型间转换。在本篇…

    编程 2025-04-28
  • Zookeeper ACL 用户 anyone 全面解析

    本文将从以下几个方面对Zookeeper ACL中的用户anyone进行全面的解析,并为读者提供相关的示例代码。 一、anyone 的作用是什么? 在Zookeeper中,anyo…

    编程 2025-04-28
  • Switchlight的全面解析

    Switchlight是一个高效的轻量级Web框架,为开发者提供了简单易用的API和丰富的工具,可以快速构建Web应用程序。在本文中,我们将从多个方面阐述Switchlight的特…

    编程 2025-04-28
  • Python合集符号全面解析

    Python是一门非常流行的编程语言,在其语法中有一些特殊的符号被称作合集符号,这些符号在Python中起到非常重要的作用。本文将从多个方面对Python合集符号进行详细阐述,帮助…

    编程 2025-04-28

发表回复

登录后才能评论