Redis 数据结构之【快速列表】

含义:

Redis 早期版本存储 list 列表数据结构使用的是压缩列表 ziplist 和普通的双向链表 linkedlist,也就是元素少时用 ziplist,元素多时用 linkedlist。 

// 链表的节点 
struct listNode<T> { 
    listNode* prev;  
    listNode* next; 
    T value; 
}
// 链表 
struct list { 
    listNode *head; 
    listNode *tail;
    long length;

考虑到链表的附加空间相对太高,prev 和 next 指针就要占去 16 个字节 (64bit 系统的指针是 8 个字节),另外每个节点的内存都是单独分配,会加剧内存的碎片化,影响内存管理效率。后续版本对列表数据结构进行了改造,使用 quicklist 代替了 ziplist 和 linkedlist 。

内部结构 :

struct ziplist {
     ...
 }
struct ziplist_compressed {
     int32 size;
     byte[] compressed_data;
 }
struct quicklistNode {
     quicklistNode* prev;
     quicklistNode* next;
     ziplist* zl; // 指向压缩列表
     int32 size; // ziplist 的字节总数
     int16 count; // ziplist 中的元素数量
     int2 encoding; // 存储形式 2bit,原生字节数组还是 LZF 压缩存储
     ...
 }
struct quicklist {
     quicklistNode* head;
     quicklistNode* tail;
     long count; // 元素总数
     int nodes; // ziplist 节点的个数
     int compressDepth; // LZF 算法压缩深度
     ...
 } 

使用: 

  • list基础数据结构

ziplist内部元素数量:

quicklist 内部默认单个 ziplist 长度为 8k 字节,超出了这个字节数,就会新起一个 ziplist。ziplist 的长度由配置参数 list-max-ziplist-size 决定。

压缩深度: 

quicklist 默认的压缩深度是 0,也就是不压缩。压缩的实际深度由配置参数 list-compress-depth 决定。为了支持快速的 push/pop 操作,quicklist 的首尾两个 ziplist 不压缩,此时深度就是 1。如果深度为 2,就表示 quicklist 的首尾第一个 ziplist 以及首尾第二个 ziplist 都不压缩。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值