2020-06-13:Redis底层数据结构?

福哥答案2020-06-13:

福哥口诀法:简链字跳整 压快压

SDS simple synamic string:简单动态字符串。支持自动动态扩容的字节数组 。
list :链表 。双端链表。
dict :字典。使用双哈希表实现的, 支持平滑扩容的字典 。
zskiplist :跳跃表。附加了后向指针的跳跃表 。
intset : 整数集合。用于存储整数数值集合的自有结构 。
ziplist :压缩列表。一种实现上类似于TLV, 但比TLV复杂的, 用于存储任意数据的有序序列的数据结构 。
quicklist:快速列表。一种以ziplist作为结点的双链表结构, 实现的非常不错 。
zipmap : 压缩字典。一种用于在小规模场合使用的轻量级字典结构 。

String底层是SDS 内部编码 int,emstr,raw 。
hash是ziplist与hashtable 。
list采取的双端链表linklist,压缩列表ziplist。
set是hashtable和inset 。
zset是ziplist和skiplist。

posted @   福大大架构师每日一题  阅读(93)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
点击右上角即可分享
微信分享提示