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的方式更节省存储资源。

相关推荐
程序员东岸几秒前
数据结构杂谈:双向链表避坑指南
数据结构·链表
hzk的学习笔记19 分钟前
Redisson解锁失败,watchdog会不会一直续期下去?
数据库·redis·缓存
Shinom1ya_25 分钟前
算法 day 46
数据结构·算法
9523630 分钟前
数据结构-链表
java·数据结构·学习
合作小小程序员小小店34 分钟前
web网页开发,在线%商城,电商,商品购买%系统demo,基于vscode,apache,html,css,jquery,php,mysql数据库
开发语言·前端·数据库·mysql·html·php·电商
TDengine (老段)42 分钟前
TDengine 字符串函数 CONCAT 用户手册
java·数据库·tdengine
一 乐1 小时前
旅游|内蒙古景点旅游|基于Springboot+Vue的内蒙古景点旅游管理系统设计与实现(源码+数据库+文档)
开发语言·前端·数据库·vue.js·spring boot·后端·旅游
bing.shao1 小时前
如何降低redis哈希值冲突概率
数据库·redis·哈希算法
ckm紫韵1 小时前
redis查询速度快的原因?
数据库·redis·缓存
yookay zhang1 小时前
达梦数据复制软件DMDRS
数据库