redis数据结构--跳表

2019-05-11  本文已影响0人  MontyOak

跳表实质是链表,通过维护多个指向其他节点的指针,达到快速访问节点的目的。
跳表查找的时间复杂度平均情况下是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;

跳表

跳表数据结构定义如下:

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

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

上一篇 下一篇

猜你喜欢

热点阅读