protobuf 、JSON、XML传输格式

曾经流行JSON、XML似乎在游戏开发领域悄然退居二线,protobuf 具备更优势。

Protocol Buffers (简称 Protobuf)是由 Google 开发的一种语言无关、平台无关、可扩展的序列化数据格式。它主要用于数据通信协议和数据存储。与 XML 相比,Protobuf 更小、更快、更简单

一、protobuf是什么

Protocol BuffersGoogle开发的一种轻量级、高效的数据交换格式。

它能够将结构化数据序列化,适用于网络传输和数据存储。

与JSON和XML相比protobuf生成的二进制数据更小,解析速度更快。

二、性能优势

Protobuf 的二进制格式使得数据包体积比JSON3-10 倍,序列化和反序列化速度比JSON5-100倍。

三、支持跨平台跨语言

Protobuf 支持多种编程语言(C++、C#、Java,JavaScript,TypeScript等),只需定义一次数据结构,即可在各个平台上使用

兼容优势,向前向后兼容,Protobuf 通过字段编号而非字段名来标识数据,新增字段不会破坏旧版程序,老版本可以忽略新字段继续运行

Protobuf 的工作流程

  1. 编写 .proto 文件:定义数据结构(message)及其属性。

  2. 使用 protoc 编译器编译 .proto 文件:生成相应语言的代码文件,如 .pb.cc 和 .pb.h 文件。

  3. 在代码中使用生成的文件:实现对数据的序列化和反序列化。

四、应用场景

protobuf并非在所有场景下都是最佳选择,对于 简单的示例或者小项目,引入protobuf需要安装环境、生成代码,反而增加了不必要的复杂度。

参考:

https://protobuf.com.cn/overview/

相关推荐
电商API&Tina4 分钟前
【电商API接口】开发者一站式电商API接入说明
大数据·数据库·人工智能·云计算·json
消失的旧时光-19431 小时前
Android 面试高频:JSON 文件、大数据存储与断电安全(从原理到工程实践)
android·面试·json
ChoSeitaku10 小时前
NO.4|protobuf网络版通讯录|httplib|JSON、XML、ProtoBuf对比
xml·json
青衫客3611 小时前
浅谈 Java 后端对象映射:从 JSON → VO → Entity 的原理与实践
java·json
qqxhb19 小时前
11|结构化输出:为什么 JSON 能让系统更稳定
json·ai编程·结构化·规范模板
弹简特1 天前
【JavaEE19-后端部分】 MyBatis 入门第三篇:使用XML完成增删改查
xml·mybatis
小黑要努力1 天前
json-c安装以及amixer使用
linux·运维·json
spencer_tseng1 天前
Tomcat server.xml <Connector> address=“0.0.0.0“
xml·tomcat
听风者一号1 天前
cssMoudle生成器
前端·javascript·json
ID_180079054732 天前
小红书笔记详情 API 接口系列 + 标准 JSON 返回参考(完整版)
数据库·笔记·json