redis的跳表

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

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

从跳表的头节点开始。

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

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

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

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

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

随机生成层数。

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

相关推荐
e***749516 分钟前
Redis——使用 python 操作 redis 之从 hmse 迁移到 hset
数据库·redis·python
2501_941112071 小时前
深入理解Python的if __name__ == ‘__main__‘
jvm·数据库·python
2501_941112051 小时前
Python Lambda(匿名函数):简洁之道
jvm·数据库·python
猿小喵1 小时前
浅谈MySQL主从复制
数据库·mysql
_Minato_1 小时前
数据库知识整理——SQL访问控制
数据库
BullSmall1 小时前
高斯数据库 (GaussDB) 使用指南
数据库·gaussdb
马克学长1 小时前
SSM旅游管理系统3ohx4(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·旅游管理系统·ssm 框架
朝新_1 小时前
Spring事务和事务传播机制
数据库·后端·sql·spring·javaee
A***27952 小时前
后端服务限流配置,Spring Cloud Gateway
java·运维·数据库
stevenzqzq2 小时前
android recyclerview缓存2_四级缓存机制
android·spring boot·缓存