高效序列化工具Protobuf
1.Protobuf简介
Protocol Buffers定义:
Protocol Buffers是Google公司开发的一种数据描述语言,类似于XML能够将结构化数据序列化,可用于数据存储、通信协议等方面。它不依赖于语言和平台并且可拓展性极强。
2.Protobuf优点
同XML相比,Protocol buffers在序列化结构化数据方面有许多优点:
*1.更简单
*2.数据描述文件只需原来的1/10至1/3
*3.解析速度是原来的20倍至100倍
*4.减少了二义性
*5.生成了更容易在编程中使用的数据访问类
*6.支持多种编程语言
Protobuf性能分析
如下图所示,Protobuf性能相对较好,应用领域包括:网络传输、配置文件、数据存储等。
3.Protobuf语法规则
1).指定字段类型
所有的字段都是标量类型:string、bool、int类型等等,当然也可以为字段指定其他的合成类型,包括枚举或其他消息类型。
2).分配标识号
在消息定义中,每个字段都有唯一的标识符。这些标识符是用来在消息的二进制格式中识别各个字段的,一旦开始使用就不能够更改。
注:[1,15]之内的标识号在编码的时候会占用一个字节。[16,2047]之内的标识号则占用2个字节。所以应该为那些频繁出现的消息元素保留[1,15]之内的标识号。
切记:要为将来有可能添加的、频繁出现的标识号预留一些标识号。最小的标识号可以从1开始,最大到229 - 1,or 536,870,911。不可以使用其中的[19000-19999]标识号,Protobuf协议实现中对这些进行了预留。如果非要在.proto文件中使用这些预留标识号,编译时就会报警。
3.)指定字段规则
所指定的消息字段修饰符必须是如下之一:
* required : 不可增加或删除的字段,必须初始化;
* optional : 可选字段,可删除,可以不初始化;
* repeated : 可重复字段(对应C#里面的List);
4).标量数值类型
一个标量消息字段可以含有一个如下的类型——该表格展示了定义于.proto文件中的类型,以及与之对应的、在自动生成的访问类中定义的类型:
4.在Unity项目中Protobuf使用方法归纳(基于当前最新版本3.11.4)
1).首先编写.proto文件:
注意、注意、注意:这里“ = ”号右边的数值不是表示进行赋值,而是分配标识号。
2).编写好.proto文件后使用protoc编译工具将文件编译成.cs文件
首先在控制台打开protoc.exe所在的路径
然后输入编译命名protoc -I=./ --csharp_out=./ proto文件名
如果出现黄色框内的内容,表示编译成功,在目录中我们可以看到已经生成了一个.cs文件。
3).导入到Unity,脚本中引入命名空间Google.Protobuf即可。
这里是用一个之前编译的Person类测试的,基本的序列化与反序列化方法如图所示,还有其他的如序列化成字符串、序列化到文件等方法。
相关文章
- MTR追踪的好工具
- 自然语言处理(NLP)-第三方库(工具包):Faiss【向量最邻近检索工具】【为稠密向量提供高效相似度搜索】【多种索引构建方式,可根据硬件资源、数据量选择合适方式】【支持十亿级别向量的搜索】
- 高效使用Python可视化工具Matplotlib
- EasyRecovery14最新个人版数据恢复工具
- Paragon NTFS15是什么?Mac外置硬盘读写必备工具
- 让你的设计更加高效便捷的5款原型设计工具
- 数据库文档生成工具
- 解决Linux安装 VMware tools 工具的方法
- 阿里又开源一款数据同步工具 DataX,稳定又高效,好用到爆!
- Winform打包工具SetupFactory 9 的使用
- javascript检验工具的比较
- 推荐一款很好用的一款扒网站的工具
- Xsolla推出全新工具,让您体验更高效的帐户管理
- 代码即格式:你用过这些高效工具吗?
- 警惕文化空谈的陷阱,落地DevOps工具才是关键
- CSV.js – 用于 CSV 解析和编码的 JS 工具库
- 推荐两个小工具MediaInfo 和 netpersec
- 2019-9-2-C#命令行解析工具
- Google的java工具类Guava
- 开发者和系统管理者最喜爱的开源工具Vim 起步学习的五个技巧
- [ 应急响应基础篇 ] 使用 Process Explorer 进程分析工具分析系统进程(附Process Explorer安装教程)