FlatBuffer入门笔记
FlatBuffer入门笔记
1 flatbuffer资料
flatbuffer下载地址:https://github.com/google/flatbuffers
flatbuffer官方使用文档:https://google.github.io/flatbuffers/index.html#flatbuffers_overview
flatbuffer官方测试用例:https://google.github.io/flatbuffers/flatbuffers_guide_use_cpp.html
2 编写IDL|Schema
2.1 IDL测试文件
引用官方测试使用的IDL
- // Example IDL file for our monster's schema.
- namespace MyGame.Sample;
- enum Color:byte { Red = , Green, Blue = }
- union Equipment { Weapon } // Optionally add more tables.
- struct Vec3 {
- x:float;
- y:float;
- z:float;
- }
- table Monster {
- pos:Vec3; // Struct.
- mana:short = ;
- hp:short = ;
- name:string;
- friendly:bool = false (deprecated);
- inventory:[ubyte]; // Vector of scalars.
- color:Color = Blue; // Enum.
- weapons:[Weapon]; // Vector of tables.
- equipped:Equipment; // Union.
- path:[Vec3]; // Vector of structs.
- }
- table Weapon {
- name:string;
- damage:short;
- }
- root_type Monster;
2.2 生成桩文件
利用flatc.exe生成IDL对应的桩代码,命令格式为
- flatc [ GENERATOR OPTIONS ] [ -o PATH ] [ -I PATH ] [ -S ] FILES... [ -- FILES...]
- flatc --cpp monster.fbs
flatbuffer使用模板编程,仅生成h文件。对应的文件名为filename_generated.h。这里生成monster_generated.h文件。
2.3 IDL数据类型
2.3.1 Table
Table是FlatBuffer定义的主要数据类型,一个Table包含一个名称(如2.1的Monster),以及一组字段(如2.1的Monster)。每个字段由名称、类型及默认值组成。
FlatBuffer每个字段都是可选的,这由FlatBUffer的线性实现机制决定:空闲字段仅填充默认占位值,而不占用分配size。
2.3.2 Struct
Struct只包含数值类型与其他struct,与Table相比,Struct使用更少的存储空间以及更快的访问速度。
2.3.3 Type
内建的数值类型有:
- 8 bit: byte (int8), ubyte (uint8), bool
- 16 bit: short (int16), ushort (uint16)
- 32 bit: int (int32), uint (uint32), float (float32)
- 64 bit: long (int64), ulong (uint64), double (float64)
内建的非数值类型有:
- vector,用[]表示
- string
- 指向其他Table、struct、enum、unions的引用
2.3.4 Enums
定义了一系列的命名常量,可以给定默认值。第一个变量的默认值为0。
2.3.5 Namespaces
可以定义嵌套的namespace,用.分割。
2.3.6 Root type
定义序列化的root table或者struct。
3 序列化与反序列化
对2.1例子的序列化和反序列化过程实现在sample_binary.cpp。
3.1 序列化
- // Build up a serialized buffer algorithmically:
- flatbuffers::FlatBufferBuilder builder; //申请一个flatbuffer
- // First, lets serialize some weapons for the Monster: A 'sword' and an 'axe'.
- auto weapon_one_name = builder.CreateString("Sword"); //在buffer中申请string
- short weapon_one_damage = ;
- auto weapon_two_name = builder.CreateString("Axe"); //在buffer中申请string
- short weapon_two_damage = ;
- // Use the `CreateWeapon` shortcut to create Weapons with all fields set.
- auto sword = CreateWeapon(builder, weapon_one_name, weapon_one_damage); //桩代码中实现
- auto axe = CreateWeapon(builder, weapon_two_name, weapon_two_damage); //
- // Create a FlatBuffer's `vector` from the `std::vector`.
- std::vector<flatbuffers::Offset<Weapon>> weapons_vector;
- weapons_vector.push_back(sword);
- weapons_vector.push_back(axe);
- auto weapons = builder.CreateVector(weapons_vector); //在buffer中序列化vector
- // Second, serialize the rest of the objects needed by the Monster.
- auto position = Vec3(1.0f, 2.0f, 3.0f);
- auto name = builder.CreateString("MyMonster");
- unsigned char inv_data[] = { , , , , , , , , , };
- auto inventory = builder.CreateVector(inv_data, );
- // Shortcut for creating monster with all fields set:
- auto orc = CreateMonster(builder, &position, , , name, inventory,
- Color_Red, weapons, Equipment_Weapon, axe.Union());
- builder.Finish(orc); // Serialize the root of the object. //序列化对象root
- // We now have a FlatBuffer we can store on disk or send over a network.
- // ** file/network code goes here :) **
3.2 反序列化
- // access builder.GetBufferPointer() for builder.GetSize() bytes
- // Instead, we're going to access it right away (as if we just received it).
- // Get access to the root:
- auto monster = GetMonster(builder.GetBufferPointer()); //获取根对象指针
- // Get and test some scalar types from the FlatBuffer.
- assert(monster->hp() == );
- assert(monster->mana() == ); // default
- assert(monster->name()->str() == "MyMonster");
- // Get and test a field of the FlatBuffer's `struct`.
- auto pos = monster->pos();
- assert(pos);
- assert(pos->z() == 3.0f);
- (void)pos;
- // Get a test an element from the `inventory` FlatBuffer's `vector`.
- auto inv = monster->inventory();
- assert(inv);
- assert(inv->Get() == );
- (void)inv;
- // Get and test the `weapons` FlatBuffers's `vector`.
- std::string expected_weapon_names[] = { "Sword", "Axe" };
- short expected_weapon_damages[] = { , };
- auto weps = monster->weapons();
- for (unsigned int i = ; i < weps->size(); i++) {
- assert(weps->Get(i)->name()->str() == expected_weapon_names[i]);
- assert(weps->Get(i)->damage() == expected_weapon_damages[i]);
- }
- (void)expected_weapon_names;
- (void)expected_weapon_damages;
- // Get and test the `Equipment` union (`equipped` field).
- assert(monster->equipped_type() == Equipment_Weapon);
- auto equipped = static_cast<const Weapon *>(monster->equipped());
- assert(equipped->name()->str() == "Axe");
- assert(equipped->damage() == );
- (void)equipped;
4 FlatBuffer原理?网上找的一些文档
https://www.jianshu.com/p/fa999434776a
FlatBuffer入门笔记的更多相关文章
- 每天成长一点---WEB前端学习入门笔记
WEB前端学习入门笔记 从今天开始,本人就要学习WEB前端了. 经过老师的建议,说到他每天都会记录下来新的知识点,每天都是在围绕着这些问题来度过,很有必要每天抽出半个小时来写一个知识总结,及时对一天工 ...
- ES6入门笔记
ES6入门笔记 02 Let&Const.md 增加了块级作用域. 常量 避免了变量提升 03 变量的解构赋值.md var [a, b, c] = [1, 2, 3]; var [[a,d] ...
- [Java入门笔记] 面向对象编程基础(二):方法详解
什么是方法? 简介 在上一篇的blog中,我们知道了方法是类中的一个组成部分,是类或对象的行为特征的抽象. 无论是从语法和功能上来看,方法都有点类似与函数.但是,方法与传统的函数还是有着不同之处: 在 ...
- React.js入门笔记
# React.js入门笔记 核心提示 这是本人学习react.js的第一篇入门笔记,估计也会是该系列涵盖内容最多的笔记,主要内容来自英文官方文档的快速上手部分和阮一峰博客教程.当然,还有我自己尝试的 ...
- redis入门笔记(2)
redis入门笔记(2) 上篇文章介绍了redis的基本情况和支持的数据类型,本篇文章将介绍redis持久化.主从复制.简单的事务支持及发布订阅功能. 持久化 •redis是一个支持持久化的内存数据库 ...
- redis入门笔记(1)
redis入门笔记(1) 1. Redis 简介 •Redis是一款开源的.高性能的键-值存储(key-value store).它常被称作是一款数据结构服务器(data structure serv ...
- OpenGLES入门笔记四
原文参考地址:http://www.cnblogs.com/zilongshanren/archive/2011/08/08/2131019.html 一.编译Vertex Shaders和Fragm ...
- OpenGLES入门笔记三
在入门笔记一中比较详细的介绍了顶点着色器和片面着色器. 在入门笔记二中讲解了简单的创建OpenGL场景流程的实现,但是如果在场景中渲染任何一种几何图形,还是需要入门笔记一中的知识:Vertex Sha ...
- unity入门笔记
我于2010年4月1日硕士毕业加入完美时空, 至今5年整.刚刚从一家公司的微端(就是端游技术+页游思想, 具体点就是c++开发, directX渲染, 资源采取所需才会下载)项目的前端主程职位离职, ...
随机推荐
- byte[]数组和int之间的转换
这里简单记录下两种转换方式: 第一种: 1.int与byte[]之间的转换(类似的byte short,long型) /** * 将int数值转换为占四个字节的byte数组,本方法适用于(低位在前,高 ...
- 注释的HALCON的程序
*关闭窗口 dev_close_window () dev_close_window () *打开指定大小.颜色背景的窗口 dev_open_window (0, 0, 768/2, 576/2, ' ...
- PATH_INFO, SCRIPT_NAME, REQUEST_URI区别示例
- css伪类与伪元素
原文:http://www.alloyteam.com/2016/05/summary-of-pseudo-classes-and-pseudo-elements/ 伪类的操作对象是文档树中已有的元素 ...
- ACM对拍程序
1.把所需对拍的代码的可执行文件a.exe b.exe放在同一目录下 2.把rand数据的代码的可执行文件c.exe放在该目录下 3.新建一个txt文件,里面添加代码,后把格式改成bat @echo ...
- Unity本地数据存储---Sqlite和JSON
2014-05-04更新 SqliteDatabase.cs这个文件的初始方法有问题,具体是如果指定URL已经存在了DB文件,就不会重新覆盖DB文件. 这导致我们修改之后的DB文件无法产生效果. 本人 ...
- 20145316《Java程序设计》实验二报告
20145316<Java程序设计>实验二报告 一.实验目的与要求 1.初步掌握单元测试和TDD. 2.理解并掌握面向对象三要素:封装.继承.多态. 3.初步掌握UML建模. 4.熟悉S. ...
- python3.6 pyinstaller 打包exe
现在的pyinstaller 最新版本已经支持python3.6版本的打包了只需要进行如下的操作即可 1. pip install pyinstaller 2. pip install --upgra ...
- Camera帧率和AE的关系
1.camera首先是通过曝光的pixel加上dummy pixel以及曝光的line加上dummy line来决定一帧的曝光时间,这一帧曝光时间的倒数就是帧率,这个没有错吧,但是看代码时候看到pre ...
- python 数据分析----numpy
NumPy是高性能科学计算和数据分析的基础包.它是pandas等其他各种工具的基础. NumPy的主要功能: ndarray,一个多维数组结构,高效且节省空间 无需循环对整组数据进行快速运算的数学函数 ...