FlatBuffers

FlatBuffers is a free software library implementing a serialization format similar to Protocol Buffers, Thrift, Apache Avro, SBE, and Cap'n Proto, primarily written by Wouter van Oortmerssen and open-sourced by Google. Like Cap'n Proto and SBE, it supports “zero-copy” deserialization, so that accessing the serialized data does not require first copying it into a separate part of memory, which makes accessing data in these formats much faster than data in formats requiring more extensive processing, such as JSON, CSV, and in many cases Protocol Buffers. Compared to other serialization formats however, the handling of FlatBuffers requires usually more code, and some operations are not possible (like some mutation operations).

FlatBuffers
Original author(s)Wouter van Oortmerssen
Initial releaseJune 17, 2014 (2014-06-17)[1]
Stable release
1.12.0 / March 12, 2020 (2020-03-12)[2]
Repository
Written inC++
Operating systemAndroid, Microsoft Windows, Mac OS X, Linux
Typeserialization format and library, IDL compiler
LicenseApache License 2.0
Websitegoogle.github.io/flatbuffers/ 

FlatBuffers is a popular project on GitHub, with 10,228 stars, 260 contributors, 1,605 forks, and 600 watchers on GitHub as of 2018-09-19.[3]

FlatBuffers can be used in software written in C++, C#, C, Go, Java, JavaScript, PHP, Python, and Rust. The schema compiler runs on Android, Microsoft Windows, Mac OS X, and Linux,[3] but games and other programs using FlatBuffers for serialization work on many other operating systems as well, including iOS, Amazon's Fire OS, and Windows Phone.[4]

Van Oortmerssen originally developed FlatBuffers for game development and similar applications.[5][1]

Although FlatBuffers has its own interface definition language to define the data to be serialized with it, it also supports schemas defined in the Protocol Buffers .proto format.[6]

Users

Some notable users of FlatBuffers:

  • Cocos2d-x, the popular free-software 2-D game programming library, uses FlatBuffers to serialize all of its game data.[7]
  • Facebook Android Client uses FlatBuffers for disk storage and communication with Facebook servers. The previously used JSON format was performing poorly.[8]


gollark: A link like `[[Bees|Apioforms]]` displays the text "Apioforms" and links to the page "Bees".
gollark: I should probably explain better.
gollark: The multiple names thing means that multiple different names (in links and such) can map to the same ID.
gollark: Unlike in Mediawiki, pages in Minoteaur are uniquely identified by their ID.
gollark: Even Minoteaur 6 had redirects, hackily.

See also

  • Comparison of data serialization formats

References

  1. Wouter van Oortmerssen (2014-06-17). "FlatBuffers: A Memory-Efficient Serialization Library". Retrieved 2017-06-15.
  2. "Releases - google/flatbuffers". Retrieved 19 May 2020 via GitHub.
  3. "GitHub — google/flatbuffers: Memory Efficient Serialization Library". GitHub. Retrieved 2018-09-19.
  4. "FlatBuffers for Unity". eXiin. 2015-09-21. Retrieved 2017-06-15. We tested flatbuffers [sic] on all major mobile platforms (iOS, Android, Amazon Os [sic], Windows Phone) we’re building on[,] and it works pretty well.
  5. "FlatBuffers Documentation". Retrieved 2017-06-21. FlatBuffers is an efficient cross platform serialization library for C++, C#, C, Go, Java, JavaScript, PHP, and Python. It was originally created at Google for game development and other performance-critical applications.
  6. Kenton Varda (2014-06-17). "Cap'n Proto, FlatBuffers, and SBE". Retrieved 2017-06-15.
  7. http://www.cocos2d-x.org/reference/native-cpp/V3.5/d7/d2d/namespaceflatbuffers.html
  8. George Xie (2015-07-31). "Improving Facebook's performance on Android with FlatBuffers". Retrieved 2017-06-15. Story load time from disk cache is reduced from 35 ms to 4 ms per story. Transient memory allocations are reduced by 75 percent. Cold start time is improved by 10-15 percent. We have reduced storage size by 15 percent.
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.