码迷,mamicode.com
首页 > 其他好文 > 详细

Redis 链表实现

时间:2020-11-04 17:37:06      阅读:16      评论:0      收藏:0      [点我收藏+]

标签:ext   指针   pre   head   节点   div   计数器   highlight   结构   

链表和链表节点的实现

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

typedef struct listNode {

    // 前置节点
    struct listNode *prev;

    // 后置节点
    struct listNode *next;

    // 节点的值
    void *value;

} listNode;

 

虽然上述结构就可以构成链表,但是Redis使用 adlist.h/list 来持有链表, 操作起来会更方便。

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 成员则是用于实现多态链表所需的类型特定函数:

  • dup 函数用于复制链表节点所保存的值;
  • free 函数用于释放链表节点所保存的值;
  • match 函数则用于对比链表节点所保存的值和另一个输入值是否相等。

Redis 链表实现

标签:ext   指针   pre   head   节点   div   计数器   highlight   结构   

原文地址:https://www.cnblogs.com/hulunbao/p/13919379.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!