大家好,我是考100分的小小码 ,祝大家学习进步,加薪顺利呀。今天说一说redis 底层数据结构「建议收藏」,希望您对编程的造诣更进一步.
简单动态字符串SDS
- 包含字符串长度,剩余可用长度,字符数组
- 用于Redis中所有的string存储
字典(map)
- 数组+链表形式,跟hashMap很像
- 链地址法解决hash冲突
- rehash使用新建hash数组链表进行数据rehash迁移,扩容是大于原数组长度的第一个2的n次幂
渐进式rehash,就是不是一次性迁移完,而是在CRUD操作时,一点点迁移 - 用于hash类型数据
链表
- 双端列表,直接有列表长度属性
- 用于list类型数据
跳跃表
- 带分值得一种有序类链表结构
- 每个节点中的level中存储分值相同的数据
- 每个level中数据都有一个前进指针
- 用于sortedSet类型
整数集合
- 底层是int数组,通过encoding决定int的长度,也可以在存储过程中进行长度升级,比如原先存储的16位整形,要存一个32位整数,就需要进行类型升级
- 升级的好处就是类型灵活,节约内存
- 用于数据量比较小并且都是整形的list类型
压缩列表
- 有内存字节数,节点个数,节点等属性的顺序型结构
- 用于整形或者长度较短的字符串的list,hash等类型
转载请注明出处 阿布的夏天
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10893.html