Redis 阅读笔记-链表
Redis链表
# 在每个链表节点使用一个adlist.h/listNode结构表示:
typeof struct listNode{
//前置节点
struct listNode *prev;
//后置节点
struct listNode *next;
//节点的值
void * value;
}
多个listNode通过prev和next指针组成双向列表
但是Redis使用adlist/list来持有列表,操作简单
typeof struct list {
//表头节点
listNode * head;
//表尾节点
listNode * tail;
//列表包含的节点数量
unsigned long len;
//节点复制函数
void *(*dup)(void *ptr);
//节点值释放函数
void (*free)(void *ptr);
//节点值对比函数
int (*match)(void *ptr,void *key);
} list;
下图是list结构和listNode结构组成的链表
Redis链表实现的特性:
1、双端: 链表节点带有prev和next指针,获取某个节点的前置节点和后置节点的复杂度都是O(1)
2、无环:表头的prev指针和表尾的next指针都是指向Null,对链表的访问以NULL为终点。
3、带表头和表尾指针:通过list结构的head指针和tail指针,获取表头和表尾的复杂度都是O(1)
4、带链表长度计数器:使用list的len属性来对链表节点进行计数,获取链表节点数量的复杂度是O(1)
5、多态:链表节点使用void *指针保存节点,并且通过list结构的dup、free、match三个属性为节点设置类型特定函数。用于保存各种不同类型的值。