Redis底层数据结构之ZSkipList

目录

    • 一、概述
    • 二、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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

[Diffusion Model 笔记]Score based

目录 概述方法怎么估计score(估计噪声就是估计score)怎么采样(给原始数据加噪声,早期大后来变小)inpainting (来自补充材料)还没有细究的地方: 概述 本文是观看以下视频的笔记&…

使用JMeter模拟设备通过MQTT发送数据

需求: 需要一个工具能够支持MQTT协议发送各种不同的数据。 目的: 模拟小型温室设备反馈,搭建一个测试环境,根据测试的数据显示硬件的状态和数值。 工具:JMeter 环境:需要配置Java运行环境。 操作步骤&a…

机器人操作系统ROS2学习—编译工作空间colcon build报错问题

在ROS2中,工作空间创建完成后,会经常需要编译工作空间。在工作空间dev_ws 下打开一个终端,通过指令Colcon build来编译工作空间。 1、这个过程有可能会出现如下错误: "colconbuild:Duplicate package names not supported" 根据…

阅读笔记——《BLEEM: Packet Sequence Oriented Fuzzing for Protocol Implementations》

【参考文献】Zhengxiong Luo, Junze Yu, Feilong Zuo, Jianzhong Liu, Yu Jiang, Ting Chen, Abhik Roychoudhury, and Jiaguang Sun. Bleem: Packet sequence oriented fuzzing for protocol implementations. In 32nd USENIX Security Symposium (USENIX Security 23), pages…

西湖大学赵世钰老师【强化学习的数学原理】学习笔记2节

强化学习的数学原理是由西湖大学赵世钰老师带来的关于RL理论方面的详细课程,本课程深入浅出地介绍了RL的基础原理,前置技能只需要基础的编程能力、概率论以及一部分的高等数学,你听完之后会在大脑里面清晰的勾勒出RL公式推导链条中的每一个部…

github two-factor authentication是个啥?

最近在逛github时,总是时不时会弹出一下界面,很烦 看到红框里的文字,这明显是强制要求做这个认证,如果不认证4天后账号将不可访问,所以今天花点时间看看怎么做这个认证,点“Enable 2FA now”进入这个界面&a…

Vue后台系统demo小计

创建项目 1.报错 Error: command failed: npm install --loglevel error --legacy-peer-deps 措施1:node.js文件夹属性 》高级 》选择第一个允许 Users(XXX\Users) (对我无用) 措施2:PowerShell(以管理员身份运行) 》 cd 想存…

java基础之java容器-Collection,Map

java容器 java容器分类一. Collection1. List①. ArrayList② . LinkedList③ . Vector 2. Queue队列①. LinkedList②. PriorityQueue 3. Set集合①. HashSet②. TreeSet 二. Map1. HashMap2.TreeMap3. Hashtable java容器分类 java容器分为两大类,分别是Collecti…

VMWare下建的CentOS7 扩容

记录一下扩容过程中踩过的坑 背景:一年半以前私有化部署了一个gitLab服务,当时只分配了30G的磁盘容量,这两天小伙伴总是反馈gitLab登不上。排查发现是因为磁盘满了 然后就开始了磁盘扩容之旅 各种 vgs\pv\pvdisplay\lv\lvm 等等都没用 一下…

ChatGPT记忆功能终于上线了, OpenAI 官方:用得越久越聪明!

原文 ChatGPT记忆功能终于上线了, OpenAI 官方:用得越久越聪明! Aitrainee | 公众号:AI进修生 🌟 记得今年2月份OpenAI发布过ChatGPT上线记忆功能的消息,我记得当时还弹出过这个窗口给我,但是仅仅体验了几…

【书生浦语第二期实战营学习笔记作业(六)】

课程文档:https://github.com/InternLM/Tutorial/tree/camp2/agent 课程作业:https://github.com/InternLM/Tutorial/blob/camp2/agent/homework.md Lagent & AgentLego 智能体应用搭建 1、Agent 理论1.1 为什么要有智能体1.2 什么是智能体1.3 智能体…

【兼职宝典】七大靠谱手机兼职副业平台,让你乐在其中,轻松实现财务自由!

数字化时代已经到来,互联网的普及与技术的飞速发展让越来越多的人开始关注兼职工作,以此增加收入、锻炼能力或追求兴趣爱好。本文将为您详细解读几种热门的兼职方式,助您找到最适合自己的兼职岗位。 一,自媒体运营:创…

Java 循环语句

文章目录 Java 循环语句一,for 循环1. for 循环结构2. for 循环案例: 输出5行HelloWord3. for 循环案例: 写出输出的结果 (格式多样性)4. for 循环案例: 遍历100以内的偶数。并获取偶数的个数,获取所有的偶数的和5. for 循环案例: 输出所有的水仙花数6. …

Jmeter中http请求时加HTTP Cookie管理器,cookie不生效问题

只是想加个cookie,就新建了cookie管理器,用的都是默认的,然后跑到怀疑自己的jmeter是不是出问题了。 还好没卸载重装。只是把策略改成netscape就好了。

【代码随想录刷题记录】LeetCode844比较含退格的字符

题目地址 1. 思路 1.1 基本思路 拿到这个题,我们要单独写一个函数去将退格后的字符串结果返回出来(生成退格后的真实的字符串),我还是想魔改 O ( n ) O(n) O(n)时间复杂度的删除数组元素的算法:【代码随想录刷题记录…

GoLand 2021.1.3 下载与安装

当前环境:Windows 8.1 x64 1 浏览器打开网站 https://www.jetbrains.com/go/download/other.html 找到 2021.1.3 版本。 2 解压 goland-2021.1.3.win.zip 到 goland-2021.1.3.win。 3 打开 bin 目录下的 goland64.exe,选择 Evaluate for free -- Evalu…

RunnerGo四月更新:强化UI自动化测试与UI录制插件功能

RunnerGo最近更新的 UI自动化测试和UI录制插件可以让测试人员更高效地布置UI自动化场景。这次优化升级的插件录制能力,可以更准确的定位元素并执行步骤,并增加了局部截图功能,准确查看定位的元素位置等。 UI插件V2.0介绍 接下来,让…

vue2左侧菜单栏收缩展开功能

目录 1. Main.vue页面代码 a. 修改侧边栏属性 b. 修改头部导航栏 c. 定义我们的变量 d. collapse函数 2. Header.vue页面代码 3. Aside.vue页面代码 vue2左侧菜单栏收缩展开目前是非常常见的,我们在日常开发过程中经常会碰到。这一小节我们就详细了解一下这个…

java多功能手机

随着科技的发展,手机的使用已经普及到每个家庭甚至个人,手机的属性越来越强大,功能也越来越多,因此人们在生活中越来越依赖于手机。 任务要求,使用所学知识编写一个手机属性及功能分析程序设计,测试各个手机…

3步教你成为微信客户管理高手,助你事半功倍!

在如今的商业世界中,与客户建立良好的关系并提供个性化的服务已成为企业成功的关键。今天就 分享三个简单的步骤,让大家成为微信客户管理的高手,事半功倍! 第一步:客户分类与精细化服务 为了更好地管理客户&#xff…