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结构组成的链表
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三个属性为节点设置类型特定函数。用于保存各种不同类型的值。

posted @ 2020-08-18 11:03  phper-liunian  阅读(94)  评论(0编辑  收藏  举报