Redis底层数据结构之ZSkipList

news2025/1/6 9:15:11

目录

    • 一、概述
    • 二、ZSkipList结构
    • 三、和平衡树和哈希表的对比

redis底层数据结构已完结👏👏👏:

  • ☑️redis底层数据结构之SDS
  • ☑️redis底层数据结构之ziplist
  • ☑️redis底层数据结构之quicklist
  • ☑️redis底层数据结构之Dict
  • ☑️redis底层数据结构之IntSet
  • ☑️redis底层数据结构之ZSkipList

一、概述

ZSkipList是一种有序数据结构,支持平均 O(logN) 复杂度的查找、插入和删除操作。优点:高效的范围查询。使用场景: 存储有序集合数据,例如 Sorted Set 类型。

二、ZSkipList结构

/* ZSETs use a specialized version of Skiplists */
typedef struct zskiplistNode {
    sds ele;
    double score;
    struct zskiplistNode *backward;
    struct zskiplistLevel {
        struct zskiplistNode *forward;
        unsigned int span;
    } level[];
} zskiplistNode;

typedef struct zskiplist {
    struct zskiplistNode *header, *tail;
    unsigned long length;
    int level;
} zskiplist;

在这里插入图片描述

ZSkipList:
header:header 是指向zskiplist的第一个节点(也就是跳表的头节点)的指针。它本质上是zskiplist的入口点,所有的操作(插入、查找、删除等)都是从这个节点开始的。header节点包含了多个指向不同层次第一个实际节点的指针,这些层级的指针帮助实现跳表的快速访问特性。
tail:tail 指向zskiplist中的最后一个节点。
length:length 表示zskiplist中节点的总数(不包括header节点)。这个数量随着节点的插入和删除动态变化。通过length可以快速获取到跳表的大小,无需遍历整个结构。
level:level 表示当前zskiplist中最高层级的层数。在跳表中,层级是动态管理的,每次插入新节点时,都会通过一定的随机化算法为其分配一个层数,level保留的是所有节点层数中的最大值。这个值允许zskiplist动态调整自身的索引结构,以适应不同的数据变化情形,同时保持操作的效率。

ZSkipListNode:
ele:ele 是存储在此节点中的实际值,即有序集合的成员。在Redis中,它通常是一个字符串。
score:score是一个浮点数,跟每个元素(即ele)相关联,表示元素在有序集合中的排序分数。按照score从小到大的顺序来为元素排序,同样的score值不会影响元素的位置。
backward:backward 是指向此节点在最低层的前一个节点的指针。这有助于实现从后向前的导航,并可支持有序集合的逆向查询。
level[]:level是一个数组,数组的元素是代表每一层的结构体。每一个结构体包含两个属性:forward和span。

  • forward:forward是一个指针,指向当前节点在这一层的下一个节点。
  • span:span表示当前节点到forward指针所指向的节点之间的间距, 紧邻的两个结点之间的距离定义为1。

在这里插入图片描述

三、和平衡树和哈希表的对比

  • 有序性:Skip List和平衡树支持元素的有序排列,而哈希表不支持。有序性使得Skip List和平衡树适合于范围查找操作,而哈希表则适用于单个键的快速查找。
  • 范围查找:范围查找在Skip List中实现相当直观和高效,仅需线性遍历链表即可完成。相较之下,平衡树实现范围查找较为复杂,可能需要进行中序遍历来访问指定范围的所有节点。
  • 插入和删除操作:平衡树的插入和删除操作可能导致树结构调整,以保持树的平衡性,逻辑较为复杂。而Skip List在插入和删除时仅需调整相邻节点的指针,操作较为简单且效率较高。
  • 内存占用:Skip List的内存占用相对于平衡树更为灵活,其每个节点包含的指针数量平均为1/(1-p),具体取决于参数p的大小。相对地,平衡树的每个节点通常包含两个指针(分别指向左右子树)。
  • 查找性能:对于单个键值的查找,Skip List和平衡树的时间复杂度大致相同,都是O(log n)。而哈希表的查找性能在理想情况下接近O(1),通常更高效。
  • 实现难度:从算法实现上来看,Skip List的实现比平衡树简单许多,这对于开发者来说是一个重要的优势。

参考 redis底层数据结构
参考 Redis底层数据结构之skiplist

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1630823.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

可替代IBM DOORS的现代化需求管理解决方案Jama Connect,支持数据迁移及重构、实时可追溯性、简化合规流程

作为一家快速发展的全球性公司,dSPACE一直致力于寻找保持领先和优化开发流程的方法。为推进其全球现代化计划,dSPACE开始寻找可以取代传统需求管理平台(IBM DOORS)的需求管理解决方案。 通过本次案例,您将了解dSPACE为…

【YOLO 系列】基于YOLO V8的火灾烟雾监控检测识别系统【python源码+Pyqt5界面+数据集+训练代码】

摘要: 火灾烟雾的及时检测对于人们的生命财产安全至关重要。然而,在大多数情况下,火灾往往在被发现时已经进展到了难以控制的阶段,这导致了严重的后果。为了解决这一问题,我们提出了基于深度学习技术的火灾烟雾检测系…

前端开发攻略---介绍HTML中的<dialog>标签,浏览器的原生弹框。

1、演示 2、介绍 <dialog> 标签用于定义对话框&#xff0c;即一个独立的窗口&#xff0c;通常用来显示对话框、提示框、确认框等弹出式内容。在对话框中&#xff0c;可以包含文本、表单元素、按钮等内容&#xff0c;用户可以和这些内容进行交互。 3、兼容性 4、示例代码 …

03-MVC执行流程-参数解析与Model

重要组件 准备Model&#xff0c;Controller Configuration public class WebConfig {ControllerAdvicestatic class MyControllerAdvice {ModelAttribute("b")public String bar() {return "bar";}}Controllerstatic class Controller1 {ResponseStatus(H…

现代永磁同步电机控制原理pdf及全套matlab仿真模型

现代永磁同步电机控制原理pdf及matlab仿真模型。全书包含SVPWM, DTC, Lun, smo, EKF, HFI等经典控制算法。将书中10章节涉及到的模型复原搭建模型。 模型获取链接&#xff1a;现代永磁同步电机控制原理pdf及全套matlab仿真模型

电商API数据采集接口||大数据的发展,带动电子商务产业链,促进了社会的进步

最近几年计算机技术在诸多领域得到了有效的应用&#xff0c;同时在多方面深刻影响着我国经济水平的发展。除此之外&#xff0c;人民群众的日常生活水平也受大数据技术的影响。 主流电商API数据采集接口||在这其中电子商务领域也在大数据技术的支持下&#xff0c;得到了明显的进…

windows环境下DVWA靶场搭建

目录 一&#xff0c;安装PHPstudy 二&#xff0c;DVWA靶场上传 一&#xff0c;安装PHPstudy 具体安装步骤&#xff0c;请看上篇文章https://blog.csdn.net/m0_72210904/article/details/138258609?spm1001.2014.3001.5501 二&#xff0c;DVWA靶场上传 压缩包&#xff1a;&…

计算机混合运算(计算器)

学习贺利坚老师,计算机混合运算, 做出处理混合运算 数据结构例程——表达式求值&#xff08;用栈结构&#xff09;_用栈表达式求值-CSDN博客文章浏览阅读1.5w次&#xff0c;点赞14次&#xff0c;收藏61次。本文针对数据结构基础系列网络课程(3)&#xff1a;栈和队列中第5课时栈…

工业异常检测

工业异常检测在业界和学界都一直是热门&#xff0c;近期其更是迎来了全新突破&#xff1a;与大模型相结合&#xff01;让异常检测变得更快更准更简单&#xff01; 比如模型AnomalyGPT&#xff0c;它克服了以往的局限&#xff0c;能够让大模型充分理解工业场景图像&#xff0c;判…

与 Apolo 共创生态:Apolo 7周年大会我的启示与心得分享

文章目录 前言一、Apolo加速企业自动驾驶解决方案落地二、应用X企业预制套件&#xff1a;启示与心得三、Studio X企业协同工具链&#xff1a;共创心得分享 前言 本篇文章我将围绕Apolo 7周年来给大家分享我所学习到的内容和一些心得。 Apolo 7周年活动链接&#xff1a;https:…

2024年【陕西省安全员C证】报名考试及陕西省安全员C证考试资料

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2024年陕西省安全员C证报名考试为正在备考陕西省安全员C证操作证的学员准备的理论考试专题&#xff0c;每个月更新的陕西省安全员C证考试资料祝您顺利通过陕西省安全员C证考试。 1、【多选题】下列做法正确的有&#…

模块化兼容性

模块化兼容性 由于webpack同时支持CommonJS和ES6 module&#xff0c;因此需要理解它们互操作时webpack是如何处理的 同模块化标准 如果导出和导入使用的是同一种模块化标准&#xff0c;打包后的效果和之前学习的模块化没有任何差异 不同模块化标准 不同的模块化标准&#x…

Vue入门到关门之计算属性与监听属性

一、计算属性 1、什么是计算属性 计算属性是基于其它属性计算得出的属性&#xff0c;就像Python中的property&#xff0c;可以把方法/函数伪装成属性&#xff0c;在模板中可以像普通属性一样使用&#xff0c;但它们是基于响应式依赖进行缓存的。这意味着只有在依赖的响应式数…

jsp servlet 学生信息管理系统

一、角色划分 1、超级管理员 2、学生 二、模块展示 1、登录 2、列表页面【超级管理员展示所有用户信息、学生只展示当前登录用户信息】 3、新增 4、编辑 三、数据库【mysql】 四、运行演示 jsp servlet 学生信息管理系统

Django模型继承之多表继承

在Django模型继承中&#xff0c;支持的第二种模型继承方式是层次结构中的每个模型都是一个单独的模型。每个模型都指向分离的数据表&#xff0c;并且可以被独立查询和创建。在继承关系中&#xff0c;子类和父类之间通过一个自动创建的OneToOneField进行连接。示例代码如下&…

新闻稿的正文应该怎样写?纯干货

新闻稿作为传播信息的重要载体&#xff0c;正文的撰写至关重要。新闻稿的正文应该怎样写&#xff1f;伯乐网络传媒来给大家揭秘高质量新闻稿的写作结构与技巧&#xff01; 一、新闻稿正文的结构 1. 导语 a. 概括新闻事件的核心内容&#xff1a;导语是新闻稿的开篇&#xff0c;…

纯血鸿蒙APP实战开发——预渲染实现Web页面瞬开效果

介绍 为了便于大家在使用本案例集时能够更详细的了解各个案例&#xff0c;本案例基于Web预渲染实现了案例介绍功能&#xff0c;即应用右下角的问号icon。 效果图预览 使用说明 因为直接加载的线上README&#xff0c;因此本功能需联网使用点击icon&#xff0c;即会弹出对应案…

跟TED演讲学英文:The secret ingredient of business success by Pete Stavros

The secret ingredient of business success Link: https://www.ted.com/talks/pete_stavros_the_secret_ingredient_of_business_success? Speaker: Pete Stavros Date: April 2024 文章目录 The secret ingredient of business successIntroductionVocabularyTranscriptSu…

前端框架技术调研

目前程序员使用前端框架最多的是哪一个&#xff1f;

WCH RISC CH32V303RCT6 单片机的SDI Printf 虚拟串口功能 类似SEGGER RTT打印功能 简单分析

参考&#xff1a; 有关于 SDI printf 更多的信息和资料吗&#xff1f; 关于 CH32 系列 MCU SDI 虚拟串口功能的使用 【CH32X035 评估板测评】 教你使用 SDI 接口重定向 printf SDI (Serial Data Interface) 是沁恒微电子 RISC-V 内核的私有外设接口,CH32 RISC-V 系列目前提供了…