美文网首页
redis(4)跳跃表

redis(4)跳跃表

作者: 大飞飞_s8 | 来源:发表于2019-09-26 19:40 被阅读0次

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

2、跳跃表支持平均O(logN) 最坏o(N)复杂度的节点查找,还可以通过顺序操作来批量处理节点,大部分情况下效率媲美平衡树,实现比平衡树简单,所以不少程序员用跳跃表来代替平衡树

3、使用场景,有序集合包含元素数量比较多,或者成员member是比较长的字符串时。

4、跳跃表实现,包含zskiplistnode zskiplist

4.1、zskiplist

header:指向跳跃表的表头节点 tail:指向跳跃表的表尾节点,level:跳跃表内,层数最大的那个节点的层数(表头节点层数不计算在内) length:跳跃表长度,,,㔓包含的节点数量,表头不计在内

4.2、zskiplistnode

level:层 每个跳跃表节点层高都是1到32之间的随机数

每个层有两个属性,前进指针和跨度,前进指针用户访问位于表尾方向的其他节点,跨度则记录前进指针所指向节点和当前节点的距离 后退(backward)指针:bw字样标记节点后退指针,后退指针从表尾向头遍历时使用

分值,各个节点按照各自保存的分值从小到大排列

成员对象obj

得分相同,则按照字典顺序排序

5、仅通过多个跳跃表节点就能组成一个跳跃表,但是通过zskiplist结构来持有这些节点,程序可以更方便的对整个跳跃表进行处理

5.1、查找表头表尾复杂度为o(1) 计算长度length复杂度为o(1)

漫画跳跃表https://www.jianshu.com/p/ac351674d8eb?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

相关文章

  • redis(4)跳跃表

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

  • 跳跃表

    redis中有序集合zset是用跳跃表实现的,所以今天学习了一下跳跃表。本文主要讲redis中跳跃表的实现。 一、...

  • redis跳跃表

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

  • Redis跳跃表

    本文摘抄自redis 源码剖析 跳跃表是一种随机化的数据,跳跃表以有序的方式在层次化的链表中保存元素,效率和平衡树...

  • 跳跃表 redis

    为什么选择跳跃表目前经常使用的平衡数据结构有:B树,红黑树,AVL树,Splay Tree, Treep等。想象一...

  • Redis 跳跃表

    什么是跳跃表 参考原文简单的说就是一种提升了查询性能的有序链表。链表好啊,插入和删除都是O(1),但是只能O(n)...

  • Redis设计与实现-笔记(二)

    数据结构与对象 跳跃表 跳跃表是有序集合的底层实现之一, 除此之外它在 Redis 中没有其他应用。 Redis ...

  • hbase 读书笔记——数据结构

    跳跃表 跳跃表广泛使用于KV数据库中,诸如Redis、LevelDB、HBase都把跳跃表作为一种维护有序数据集合...

  • redis笔记:跳跃表

    本人博客同步发表,排版更佳 通过在每个节点中维持多个只想其他节点的指针,从而达到快速访问节点的目的。 作为redi...

  • Redis 跳跃表(skiplist)

    Redis基础类型中的有序集合、集群节点的内部数据结构用到了跳跃表(skiplist)。 5.1 跳跃表的实现 图...

网友评论

      本文标题:redis(4)跳跃表

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