`

谷歌开源高效、跨平台的序列化库FlatBuffers

 
阅读更多

近日,谷歌“Fun Propulsion Labs”团队 开源了FlatBuffers 。该库的构建是专门为游戏开发人员的性能需求提供支持,它将序列化数据存储在缓存中,这些数据既可以存储在文件中,又可以通过网络原样传输,而不需要任何解析开销。

FlatBuffers有如下一些关键特性——

  • 访问序列化数据不需要打包/拆包
  • 节省内存而且访问速度快——缓存只占用访问数据所需要的内存;不需要任何额外的内存。
  • 灵活性——通过可选字段向前向后兼容
  • 代码规模小
  • 强类型——错误在编译时捕获,而不是在运行时
  • 便利性——生成的C++头文件代码简洁。如果需要,有一项可选功能可以用来在运行时高效解析Schema和JSON-like格式的文本。
  • 跨平台——使用C++编写,不依赖STL之外的库,因此可以用于任何有C++编辑器的平台。当前,该项目包含构建方法和在Android、Linux、Windows和OSX等操作系统上使用该库的示例。

与Protocol Buffers或JSON Parsing这样的可选方案相比,FlatBuffers的优势在于开销更小,这主要是由于它没有解析过程。

在C++中使用FlatBuffers包含以下步骤——

  • 使用专用的DSL 创建schema文件
  • 使用schema编译器 生成C++头文件
  • 在用户程序中包含生成的头文件(而且需要在路径中包含flatbuffers/flatbuffers.h文件)
  • 使用FlatBufferBuilder类(它会构造一个平面二进制缓冲区) 读写数据

正如前期 讨论组 中的讨论,FlatBuffers明显有些不完善的地方。对Java的支持还在试验阶段。对C3#的支持是要求最多的功能之一,可能在下个版本提供。

读者可以查阅 文档 来了解更多信息。

Cap’n Proto 也是一个值得了解一下的项目,它旨在通过避免编码/解码过程来获得性能收益。

查看英文原文:Google Open-Sources FlatBuffers:Efficient, Cross-Platform, Serialization Library

分享到:
评论

相关推荐

    FlatBuffers:高效内存序列化库-开源

    FlatBuffers是一个开放源代码,跨平台的序列化库,旨在最大程度地提高内存效率。 FlatBuffers最初由Google创建,用于游戏开发和其他对性能有严格要求的应用程序,它具有独特的功能,可让您直接访问序列化数据,而...

    flatbuffers源码 java序列化工具库供大家学习

    FlatBuffers是一个开源的、跨平台的序列化工具库,它提供了C++和Java等语言的接口。这个库由Google专门为游戏开发或其他性能敏感的应用程序需求而创建,尤其在内存大小及带宽受限的移动平台上表现出色。一个独特的...

    c++开源库大全21

    - **FlatBuffers**:内存高效的序列化库,允许直接访问序列化数据而无需解包。 - **MessagePack**:提供JSON类似的二进制序列化库,适合高效数据交换。 - **protobuf (Protocol Buffers)**:Google的数据交换格式...

    flatc1.1.0

    Flatbuffers是一种面向性能的序列化库,由Google开发并开源。与许多其他序列化库不同,Flatbuffers允许直接访问序列化后的数据,而无需进行反序列化,这极大地提高了读取速度。flatc是这个库的命令行工具,用于编译...

    fips-flatbuffers:用于 http 的 fips 模块

    总结来说,fips-flatbuffers是FIPS构建系统的一个组件,它整合了Google的Flatbuffers库,特别是在HTTP服务中用于高效的数据序列化和反序列化。通过提供Python绑定,这个模块也使得Python开发者能够利用Flatbuffers来...

Global site tag (gtag.js) - Google Analytics