redis底层数据结构之skiplist实现

skiplist实现

skiplist跳跃表,是一种有序数据结构,通过在每个节点中维持多个指向其他节点的指针,来达到快速访问节点的目的,redis使用skiplist作为zsort的底层实现之一

结构很像树形结构

typedef struct zskiplistNode {
    
   // 对象
    sds ele;
   // 分值
    double score;
   // 后退指针,从表尾向表头方向的访问及诶按
    struct zskiplistNode *backward;
   // 层  数组中可以包含多个元素,每个元素都包含一个指向其他节点的指针
    struct zskiplistLevel {
       // 前进指针,从表头向表尾方向访问节点
        struct zskiplistNode *forward;
       // 跨度,记录两个节点间的距离,跨度值是两个节点score的差值
        unsigned long span;
    } level[];
} zskiplistNode;

typedef struct zskiplist {
   // 头尾节点
    struct zskiplistNode *header, *tail;
   // 跳跃表的长度
    unsigned long length;
   // 记录目前跳跃表的深度(表头节点的层数不计算在内)
    int level;
} zskiplist;

https://zhhll.icu/2021/数据库/非关系型数据库/redis/底层实现/2.skiplist实现/

本文由 mdnice 多平台发布

相关推荐

  1. redis底层数据结构skiplist实现

    2023-12-14 05:00:08       70 阅读
  2. redis底层数据结构ziplist实现

    2023-12-14 05:00:08       60 阅读
  3. Redis数据结构-跳跃表 skiplist

    2023-12-14 05:00:08       20 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-14 05:00:08       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-14 05:00:08       101 阅读
  3. 在Django里面运行非项目文件

    2023-12-14 05:00:08       82 阅读
  4. Python语言-面向对象

    2023-12-14 05:00:08       91 阅读

热门阅读

  1. Matlab程序设计

    2023-12-14 05:00:08       59 阅读
  2. ffmpeg从视频文件中截取一段视频

    2023-12-14 05:00:08       63 阅读
  3. 低代码开发:数字化“装配线”的崛起

    2023-12-14 05:00:08       54 阅读
  4. wordpress301重定向传权

    2023-12-14 05:00:08       50 阅读
  5. 算法笔记—二分搜索

    2023-12-14 05:00:08       53 阅读