Redis学习笔记:链表

概述

链表提供了高效的节点重排能力,以及顺序性的节点访问方式,并且可以通过增删节点来灵活地调整链表的长度。链表在Redis中的应用非常广泛,比如列表键的底层实现之一就是链表。还有发布与订阅、慢查询、监视器等。

实现

链表节点使用一个adlist.h/listNode结构来表示:

cpp 复制代码
typedef struct listNode{
    //  前置节点
    struct listNode *prev;
    //  后置节点
    struct listNode *next;
    //  节点的值
    void *value;
} listNode;

虽然使用多个listNode结构就可以组成链表,但使用adlist.h/list来持有链表的话,操作起来会更方便:

cpp 复制代码
typedef 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结构为链表提供了表头指针head、表尾指针tail,以及链表长度计数器len,而dup、free和match成员则是用于实现多态链表所需的类型特定函数。如图是由一个list结构和三个listNode结构组成的链表:

Redis实现的是双端无环链表,链表节点带有prev和next指针,带链表长度计数器,Redis实现的链表是多态的,链表节点使用void*指针来保存节点值,并且可以通过list结构的dup、free、match三个属性为节点值设置类型特定函数,所以链表可以用于保存各种不同类型的值。

参考

《Redis设计与实现》

相关推荐
chase。4 分钟前
【学习笔记】Unified World Models:基于视频-动作耦合扩散的机器人预训练新范式
笔记·学习·音视频
一锅炖出任易仙29 分钟前
创梦汤锅学习日记day32
学习·ai·游戏引擎
影寂ldy1 小时前
C# 事件完整学习笔记(发布订阅 + 自定义事件 + 内置 EventHandler)
笔记·学习·c#
fox_lht2 小时前
15.4.循环和迭代器的性能比较
开发语言·后端·学习·rust
海绵宝宝的月光宝盒2 小时前
6-机械设计基础物理知识
经验分享·笔记·其他·职场和发展·课程设计·学习方法
淮南颂恩少儿编程C++2 小时前
在淮南:编程信息学培训与 C++ 信奥赛:从 CSP 到 NOI 的进阶之路
人工智能·学习·青少年编程
闪闪发亮的小星星2 小时前
卫星通信、主要业务类型、组成
笔记
十月的皮皮2 小时前
C语言学习笔记20260612-菱形图案打印(两种写法)
c语言·笔记·学习
chase。2 小时前
【学习笔记】RIGVid:通过模仿生成视频实现机器人操作,无需物理演示
笔记·学习·音视频
c7693 小时前
【文献笔记】Learn to Relax with LLMs: Solving COPs via Bidirectional Coevolution
论文阅读·人工智能·笔记·语言模型·论文笔记·提示工程