redis的跳表

csharp 复制代码
typedef struct zskiplistNode {
    // 分值
    double score;
    // 成员对象
    robj *obj;
    // 后退指针
    struct zskiplistNode *backward;
    // 层
    struct zskiplistLevel {
        // 前进指针
        struct zskiplistNode *forward;
        // 跨度
        unsigned int span;
    } level[];
} zskiplistNode;

跳表的节点查找算法可以描述如下:

从跳表的头节点开始。

在当前层级上,从最右侧开始,逐个比较节点的值,直到找到一个节点的值大于或等于目标值。

如果当前节点的值等于目标值,则返回该节点,查找结束。

如果当前节点的值大于目标值,则向下移动到下一层级。

重复步骤2和3,直到找到目标节点或者到达跳表的底层。

跳表的插入算法描述如下:

随机生成层数。

插入新节点时,需要在每一层都更新对应的指针,使得新节点能够正确地插入到每一层中。

相关推荐
yumgpkpm几秒前
CMP(类ClouderaCDP7.3(404次编译) )完全支持华为鲲鹏Aarch64(ARM),粉丝数超过200就开源下载
hive·hadoop·redis·mongodb·elasticsearch·hbase·big data
en-route13 分钟前
使用缓存版本号解决缓存一致性问题
缓存
大G的笔记本1 小时前
MySQL 大表查询优化、超大分页处理、SQL 慢查询优化、主键选择
数据库·sql·mysql
Lear1 小时前
Redis 持久化机制
数据库
儒道易行2 小时前
【攻防实战】Redis未授权RCE联动metasploit打穿三层内网(上)
数据库·redis·网络安全·缓存
小宁爱Python2 小时前
从零搭建 RAG 智能问答系统 6:Text2SQL 与工作流实现数据库查询
数据库·人工智能·python·django
yjsstar2 小时前
数据库MySQL基础
数据库·mysql
云边有个稻草人2 小时前
KingbaseES数据库性能调优指南:从理论到实践的全链路解析
数据库·金仓数据库
TG_yunshuguoji2 小时前
亚马逊云渠道商:AWS 本地 SSD 缓存是什么?
缓存·云计算·aws
nianniannnn2 小时前
Qt布局管理停靠窗口QDockWidget类
开发语言·数据库·c++·qt·qt5·qt6.3