华域联盟 Redis redis底层数据结构之skiplist实现示例

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;

以上就是redis底层数据结构之skiplist实现示例的详细内容,更多关于redis底层数据结构skiplist的资料请关注脚本之家其它相关文章!

本文由 华域联盟 原创撰写:华域联盟 » redis底层数据结构之skiplist实现示例

转载请保留出处和原文链接:https://www.cnhackhy.com/157506.htm

本文来自网络,不代表华域联盟立场,转载请注明出处。

作者: sterben

发表回复

联系我们

联系我们

2551209778

在线咨询: QQ交谈

邮箱: [email protected]

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们