Level DB --- coding

Util coding是Level DB中重要的数据结构,它主要用来将uint32,和uint64高效的序列化到字符串中和从字符串中反序列化出来。

coding两种序列化形式

Util coding中主要提供两种序列化形式,即Fixed形式和Var形式。其中Fixed形式是常规形式,如图1所示,可以看到每一个uint32的数字,在内存中占4个字节,在序列化的字符串中也占4个字节。

图1. Fixed mode 序列化

对于Var形式,同样是uint32的数字,它序列化的字节数是可变的。如图2所示,这种形式每一个字节(byte),前7位(bit)用于存有效数字,第8位(bit)用于存储flag。flag的设计如下:1.当当前字节不是最后一个序列化字节的时候,flag为1;当当前的字节是最后一个字节的时候,flag为0。同样是uint32_t 789,序列化只需要2个字节。

图2. Var mode 序列化

总结

可以看到Fixed形式,在序列化的时候固定占用4个字节,而Var形式占用的字节数目是不固定的,一个字节(byte),它有7位(bit)是有效存储数据,1位(bit)存储flag。对于都是比较小的数字,Var的方式更节省存储资源。

相关推荐
_3762715314 小时前
怎样查询不同表的字段差异 information_schema结构对比
jvm·数据库·python
YL2004042614 小时前
MySQL-进阶篇-存储引擎
数据库·mysql
weixin_4440129314 小时前
宝塔面板如何实现网站重定向_配置301永久跳转与域名更换
jvm·数据库·python
m0_7335654614 小时前
CSS如何高效命名样式类_掌握BEM规范提升语义化程度
jvm·数据库·python
lzh2004091914 小时前
MySQL零基础入门:从建库到增删改查
数据库·mysql
woxihuan12345614 小时前
CSS如何引入自适应图标_利用svg外链配合css控制颜色
jvm·数据库·python
2401_8800714014 小时前
如何正确合并多个 Word 文档(.docx)并保留格式与分页
jvm·数据库·python
如君愿14 小时前
考研复习 Day 34 | 习题--计算机网络 第六章(应用层 下)、数据结构 查找算法(下)
数据结构·计算机网络·考研·课后习题
瀚高PG实验室14 小时前
瀚高数据库V45及V6用户锁定后解锁步骤
运维·数据库·瀚高数据库
Languorous.14 小时前
数据结构初阶|二叉树入门,从零到一吃透基础
数据结构