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

protobuffer总结

protobuffer是一种语言无关、平台无关的数据协议,优点在于压缩性好,可扩展,标准化,常用于数据传输、持久化存储等。...图片实现原理protobuffer协议1 压缩性好(相比于同样跨平台、跨语言的json)去除字段定义,分隔符(引号,冒号,逗号)压缩数字,因为日常经常使用到的比较小的数字,实际有效的字节数没有4个字节采用...TLV的数据存储方式:减少了分隔符的使用 & 数据存储得紧凑varint和zigzag算法:对数字进行压缩protobuffer协议去除字段定义,分隔符这里有几篇文章对protobuffer总结的很好https...可拓展性在于protobuffer中追加定义,新旧版本是可以兼容的,但是定义是严格有序的。...3 标准化protobuffer生态提供了完整的工具链,protobuffer提供官方的生成golang/java等实现插件,这样protobuffer字节码的各语言版本的序列化、反序列化是标准化的,也包括插件生成代码封装

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

聊聊gRPC的接口描述语言ProtoBuffer(二)

什么是ProtoBuffer ProtoBuffer是一种与语言无关,平台无关,可扩展的序列化结构化数据的方法,用于通信协议,数据存储等,ProtoBuffer由Google开发,目前各大互联网公司普遍使用...ProtoBuffer的特点 相比xml,json等数据序列化方式,ProtoBuffer具有如下特点 体积小3到10倍,(其数据格式紧密,没有多余的空格,括号,尖括号,key等) 性能快20到100倍...最终生成的代码如下,截取一些核心代码,我们可以看到protobuffer编译器将proto文件能够转化为go的struct ? ProtoBuffer的原理 什么是Base 128 varint?...如下: ‭111111111111111111111111_11111111‬,如果也采用varint编码那么就需要至少占用5个字节,这显然有些浪费空间,ProtoBuffer的解决方案如下: ProtoBuffer...总结 ProtoBuffer编解码方式简单(只需要简单的数学运算,位运算) ProtoBuffer数据压缩方式好,占用的空间小 ProtoBuffer兼容性好,采用TLV的存储格式

1.2K20
领券