首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

protobuf编码原理

而与之对应的protobuf在编解码时性能要优于json,下面主要对protobuf编码原理做个分析,弄懂protobuf编码效率很高的原因。...简介 下面是官方文档对protobuf的定义,大体意思是protocol buffers是一种语言无关、平台无关、可扩展的序列化结构数据的方法,可用于数据通信协议和数据存储等。...编码原理 protobuf高效的秘密在于它的编码格式,它采用了TLV(tag-length-value)编码格式。每个字段都有唯一的tag值,它是字段的唯一标识。...Varint编码原理 Varint顾名思义就可变的int,是一种变长的编码方式。值越小的数字,使用越少的字节表示,通过减少表示数字的字节数从而进行数据压缩。...所以protobuf定义了sint32和sint64类型来表示负数,先采用Zigzag编码,将有符号的数转成无符号的数,在采用Varint编码,从而减少编码后字节数。

86340
您找到你想要的搜索结果了吗?
是的
没有找到

Protobuf编码原理及优化技巧探讨

作者:carmark 本文将在proto3语法背景下,介绍protobuf的编码原理,并结合业务场景探讨部分优化技巧。...1、Protobuf编码原理介绍 序列化算法被广泛应用于各种通信协议中,本文对序列化算法进行狭义定义: 将某个struct或class的内存数据和通信数据链路上的字节流进行互相转化的算法。...1、基本类型:定点数值类型、浮点数值类型、字符串类型 2、复合类型:结构体类型、数组类型、map类型 protobuf也是对这些类型进行序列化的,下文将在proto3语法的背景下介绍protobuf对不同类型的编码原理...2、 优化技巧探讨 通过分析protobuf的编码原理,可以发现如果对序列化后的字节流长度有要求,无脑地定义数据结构是很不理智的,本节将讨论部分优化技巧。...编码原理的介绍那部分可以看出,protobuf因为考虑兼容性原因,存储了很多tagid、length这些记录结构信息的字段。

41621

【Android Protobuf 序列化】Protobuf 简介 ( Protobuf 项目简介 | Protobuf 优缺点分析 )

文章目录 一、Protobuf 简介 二、Protobuf 优缺点分析 1、Protobuf 优点 2、Protobuf 缺点 三、参考资料 一、Protobuf 简介 ---- Protobuf 是...使用场景 : 数据交换 : 从网络中下载数据 , 发送数据给服务器 ; 数据存储 : 获取或生成的数据 , 需要存储下来 ; Protobuf 语言特点 : Protobuf 包含一套 " 数据结构接口描述语言...://github.com/protocolbuffers/protobuf Protobuf 当前支持的编程语言 , 平台 ; 一套 Protobuf 源文件 , 可以编译出不同的语言的源代码 , 支持的语言类型如下...: 二、Protobuf 优缺点分析 ---- 1、Protobuf 优点 性能方面 : 体积小 : Protobuf 序列化后 , 体积小 , 序列化后 , 大约是 JSON / XML 等文本方式的...Protobuf 参考资料 : Protobuf 官网主页 : https://developers.google.com/protocol-buffers Protobuf 语法指南 : https

2.7K30

【Android Protobuf 序列化】Protobuf 使用 ( Protobuf 使用文档 | 创建 Protobuf 源文件 | Protobuf 语法 )

文章目录 一、Protobuf 使用文档 二、创建 Protobuf 源文件 三、Protobuf 语法 四、参考资料 一、Protobuf 使用文档 ---- Protobuf Java 语言对应用法...: https://developers.google.com/protocol-buffers/docs/javatutorial 使用时 , 参考上述页面的文档说明 , 进行开发 ; 二、创建 Protobuf...语法 ---- 设置 protobuf 语法版本 : Protocol Buffers 有 proto2 和 proto3 两个版本 , 这两个版本之间的 语法 , 与 底层实现 都有一定的不同 ;...参考资料 : Protobuf 官网主页 : https://developers.google.com/protocol-buffers Protobuf 语法指南 : https://developers.google.com.../docs/javatutorial Protobuf 源码地址 : https://github.com/protocolbuffers/protobuf

98030

【Android Protobuf 序列化】Protobuf 使用 ( Protobuf 源码分析 | 创建 Protobuf 对象 )

文章目录 一、Protobuf 源码分析 二、创建 Protobuf 对象 三、完整代码示例 四、参考资料 一、Protobuf 源码分析 ---- Protobuf 源文件如下 : addressbook.proto...序列化】Protobuf 使用 ( protobuf-gradle-plugin 插件简介 | Android Studio 中配置插件 | AS 中编译源文件 ) 中 , 使用了 Gradle 插件..., 自动将 Android Studio 工程中的 Protobuf 编译成了 Java 源码 , 现在开始使用生成的 Java 源码进行开发 ; 在 Protobuf 源码 addressbook.proto...Protobuf 源码地址 : https://github.com/protocolbuffers/protobuf Protobuf 发布版本下载地址 : https://github.com.../protocolbuffers/protobuf/releases protobuf-gradle-plugin 项目地址 : https://github.com/google/protobuf-gradle-plugin

69850

ProtoBuf】1.初识ProtoBuf

通过Json、XML、ProtoBuf可以实现序列化。(本文讲的就是ProtoBuf) 二. ProtoBuf 1. 什么是ProtoBuf ProtoBuf概念:将结构化数据进行序列化的一种方式。...ProtoBuf的特点 简单来讲,ProtoBuf(全称为Protocol Buffer)是让结构数据序列化的⽅法。 一....本身特点: 语⾔⽆关、平台⽆关:即ProtoBuf⽀持Java、C++、Python等多种语⾔,⽀持多个平台。 ⾼效:即⽐XML和Json更⼩、更快、更为简单。...使用特点: ProtoBuf是需要依赖 通过编译生成的头文件和源文件 来使用的。(针对C++来说) 在定义类时,需要进行三件事情: 定义一系列属性字段。 处理字段的方法:如get、set。...ProtoBuf进行序列化反序列化的流程 在ProtoBuf中,将类(class)称之为消息(message) 依赖通过编译生成的头文件和源文件实际上就是通过message XXX生成class XXX

17040

【Android Protobuf 序列化】Protobuf 使用 ( Protobuf 序列化 | Protobuf 反序列化 )

文章目录 一、Protobuf 序列化 二、Protobuf 反序列化 三、完整代码 四、参考资料 一、Protobuf 序列化 ---- 在上一篇博客 【Android Protobuf 序列化】Protobuf...使用 ( Protobuf 源码分析 | 创建 Protobuf 对象 ) 中 , 创建了 Protobuf 对象 , 本博客中将其序列化 , 保存到本地文件中 ; 序列化操作 : 调用 Protobuf...I/MainActivity: 序列化耗时 4 ms , 序列化大小 34 字节 二、Protobuf 反序列化 ---- 反序列化操作 : 调用 Protobuf 对象的 parseFrom 方法...Protobuf 语法指南 : https://developers.google.com/protocol-buffers/docs/proto Protobuf Java 语言对应用法.../protocol-buffers/docs/downloads Protobuf 源码地址 : https://github.com/protocolbuffers/protobuf Protobuf

67340

protobuf介绍

Protobuf介绍什么是ProtobufProtobuf,全称为Protocol Buffers,是Google开发的一种轻量级的数据交换格式。...Protobuf的特点简洁的结构定义语言Protobuf使用一种简洁的结构定义语言来定义数据结构和消息格式。这种语言具有类似于C语言的语法,使用起来非常直观和简单。...Protobuf使用二进制格式进行数据的序列化和反序列化,这种格式更加紧凑,占用的存储空间更小,传输速度更快。可扩展性和兼容性Protobuf支持数据结构的向前和向后兼容。...当需要读取数据时,可以使用Protobuf将二进制数据反序列化为学生和班级对象,方便进行数据操作和展示。 通过使用Protobuf,可以简化数据的存储和传输过程,提高系统的性能和可靠性。...通过使用Protobuf,开发人员可以更轻松地定义和处理复杂的数据结构,并在不同的平台和语言之间进行数据交换。虽然Protobuf在许多方面都有很多优点,但它也有一些缺点。

21800

Golang Gin 实战(十二)| ProtoBuf 使用和源码分析原理实现

的源代码分析原理实现 Gin Render机制分析 Gin如何优雅的面向接口编程 ProtoBuf数据结构 ProtoBuf的数据结构都是通过.proto文件进行定义的,然后再通过ProtoBuf工具生成相应平台语言的类库...Gin ProtoBuf 源代码分析原理实现 那么Gin是如何实现ProtoBuf序列化的呢?我们从Gin的源代码分析上来看Gin比较优雅的实现,以及Gin的面向接口的编程。...剩下的精彩内容请点击: Golang Gin 实战(十二)| ProtoBuf 使用和源码分析原理实现 精彩文章推荐 Golang Gin 实战(十一)| HTML模板渲染 Golang Gin 实战(...(九)| JSONP跨域和劫持 Golang Gin 实战(八)| JSON渲染输出 Golang Gin 实战(七)| 分组路由源代码分析 Golang Gin 实战(六)| 获取Form表单参数和原理分析...Golang Gin 实战(五)| 接收数组和map Golang Gin 实战(四)| URL查询参数的获取和原理分析 Golang Gin 实战(三)| 路由参数 Golang Gin 实战(二)

2.7K20

protobuf详解

protobuf详解 ? 一、什么是protobuf protobuf全称Google Protocol Buffers,是google开发的的一套用于数据存储,网络通信时用于协议编解码的工具库。...protobuf是一种灵活高效的独立于语言平台的结构化数据表示方法。在通信协议和数据存储等领域中使用比较多。protobuf对于结构中的每个成员会提供set系列函数和get系列函数。...与XML相比,protoBuf更小更快更简单。你可以用定义protobuf的数据结构。用protobuf编译器生成特定语言的源代码,如C++,Java,Python等。...通过protobuf内置的set函数进行赋值,赋值完成后将protobuf序列化成二进制流。目前针对于c++语言,protobuf提供了如下序列化函数: ?...(4) 反序列化protobuf 将已经序列化的二进制流反序列化,同样也是调用protobuf提供的内置函数。针对于c++,protobuf提供了如下几种常用的反序列化函数: ?

22K73
领券