美文网首页
redis数据结构--跳表

redis数据结构--跳表

作者: MontyOak | 来源:发表于2019-05-11 22:57 被阅读0次

跳表实质是链表,通过维护多个指向其他节点的指针,达到快速访问节点的目的。
跳表查找的时间复杂度平均情况下是O(logN),最坏情况是O(N)。跳表作用类似于平衡树,实现上却比平衡树简单不少。
Redis中使用跳表作为有序集合键的底层实现之一。当有序集合元素较多时,或有序集合中元素为较长字符串时,都会使用跳表作为底层结构。
Redis在两个地方用到了跳表,一种是有序集合键中,另一种是集群节点中做内部数据结构。

跳表节点

typedef struct  zskiplistNode {
  struct zskiplistLevel {
    struct zskiplistNode *forward; // 前进指针
    unsigned int span; // 跨度 
  } level[]; // 层
  struct zskiplistNode *backward; // 后退指针
  double score; //分数
  robj *obj; // 成员对象
} zskiplistNode;
  • 层 跳表节点的level数组包含指向其他节点的指针,一般来说,层数越多,跨度就越小,节点查找速度就越快。
  • 前进节点 每层都有指向表尾方向的前进指针,用于按score升序访问节点。
  • 跨度 层的跨度记录两个节点之间的距离,跨度可以用来找到节点并快速计算节点的rank。
  • 后退指针 与前进指针不同,后退指针在节点维度是每个节点只有一个,所以后退操作每次只能进行一步。
  • 分值和成员 分值用来将节点排序,节点成员底层实际上是一个SDS对象。

跳表

跳表数据结构定义如下:

typedef struct zskiplist {
  struct zskiplistNode *header, *tail; // 跳表头结点,尾结点
  unsigned long length; // 表中节点个数
  int level; // 表中最大层级数
} zskiplist;

可以看出跳表数据结构存放了跳表的元数据,用来快速访问头尾节点,计算元素总数,最大层高。

相关文章

  • 定时器实现 & 红黑树,跳表

    跳表:是为一个有序的链表建立多级索引的数据结构叫做跳表。redis中zset数据量大时底层数据结构使用跳表。 re...

  • 【算法打卡60天】Day36跳表:为什么Redis一定要用跳表来

    Day36学习内容 :跳表:为什么Redis一定要用跳表来实现有序集合?跳表是一种动态数据结构,实现灵活,可以通过...

  • 2.跳表的基本实现和特性

    一、跳表 跳表的设计与实现为啥 redis 使用跳表(skiplist)而不是使用 red-black redis...

  • Redis深度历险-跳表

    Redis深度历险-跳表 跳表是一个比较经典的数据结构,非常有用但又不像红黑树那么复杂,非常值得学习;在Ridis...

  • 数据结构 - 跳表skiplist

    更多数据结构内容,请参考:数据结构 - 概要 简介 漫画算法:什么是跳跃表? Redis 为什么用跳表而不用平衡树...

  • 跳表SkipList

    因为这个周末加班,一直没有更新,实属抱歉,今天,我们来聊一聊一个数据结构,跳表。跳表是redis的一个核心组件,也...

  • redis数据结构--跳表

    跳表实质是链表,通过维护多个指向其他节点的指针,达到快速访问节点的目的。跳表查找的时间复杂度平均情况下是O(log...

  • 有关跳跃表的干货都在这里

    跳表的数据结构 跳表全称叫做跳跃表,简称跳表。跳表是一个随机化的数据结构,实质就是一种可以进行二分查找的有序链表。...

  • HBase内存管理之MemStore

    基于跳表实现的MemStore基础模型 实现MemStore模型的数据结构是SkipList(跳表),跳表可以实现...

  • Redis为什么用跳表而不用平衡树?

    Redis为什么用跳表而不用平衡树? 本文是《Redis内部数据结构详解》系列的第六篇。在本文中,我们围绕一个Re...

网友评论

      本文标题:redis数据结构--跳表

      本文链接:https://www.haomeiwen.com/subject/nmnfaqtx.html