Redis数据结构之跳跃表

Posted 编程人,在天涯

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Redis数据结构之跳跃表相关的知识,希望对你有一定的参考价值。

  跳跃表是一种有序数据结构,它通过在每个节点中维持多个指向其他节点的指针,从而达到快速访问节点的目的。

 

一、跳跃表结构定义
1. 跳跃表节点结构定义:

2. 跳跃表结构定义:

示例:

 

二、跳跃表节点中各种结构的作用
1. 层:用于加快访问其他节点的速度,一般来说,层的数量越多,访问其他节点的速度就越快。
2. 前进指针:用于从表头向表尾方向访问节点。
3. 跨度:用于计算排位。在查找某个节点的过程中,将沿途访问过的所有层的跨度累计起来,得到的结果就是目标节点在跳跃表中的排位。
4. 后退指针:用于从表尾向表头方向访问节点。
5. 分值和成员:跳跃表中所有节点都按分值从小到大排序。

 

三、跳跃表在Redis中的用途
Redis只在两个地方使用到了跳跃表:
1. 作为有序集合键的底层实现之一: 如果一个有序集合包含的元素数量比较多,又或者有序集合中元素的成员是比较长的字符串时,Redis就会使用跳跃表来作为有序集合键的底层实现。
2. 在集群节点中用作内部数据结构。

 

以上是关于Redis数据结构之跳跃表的主要内容,如果未能解决你的问题,请参考以下文章

Redis数据结构之跳跃表

Redis源码解析之跳跃表

Redis源码解析之跳跃表

Redis源码解析之跳跃表

Redis源码之跳表数据结构

Redis跳跃表