当前位置: 首页 > news >正文

redis底层数据结构之skiplist实现

skiplist实现

skiplist跳跃表,是一种有序数据结构,通过在每个节点中维持多个指向其他节点的指针,来达到快速访问节点的目的,redis使用skiplist作为zsort的底层实现之一

结构很像树形结构

typedef struct zskiplistNode {
   // 对象
    sds ele;
   // 分值
    double score;
   // 后退指针,从表尾向表头方向的访问及诶按
    struct zskiplistNode *backward;
   // 层  数组中可以包含多个元素,每个元素都包含一个指向其他节点的指针
    struct zskiplistLevel {
       // 前进指针,从表头向表尾方向访问节点
        struct zskiplistNode *forward;
       // 跨度,记录两个节点间的距离,跨度值是两个节点score的差值
        unsigned long span;
    } level[];
} zskiplistNode;

typedef struct zskiplist {
   // 头尾节点
    struct zskiplistNode *header, *tail;
   // 跳跃表的长度
    unsigned long length;
   // 记录目前跳跃表的深度(表头节点的层数不计算在内)
    int level;
} zskiplist;

https://zhhll.icu/2021/数据库/非关系型数据库/redis/底层实现/2.skiplist实现/

本文由 mdnice 多平台发布

http://www.lryc.cn/news/261660.html

相关文章:

  • mjpg-streamer配置其它端口访问视频
  • C++相关闲碎记录(15)
  • 汽车IVI中控开发入门及进阶(十一):ALSA音频
  • Gradle 之初体验
  • 【Spark精讲】Spark内存管理
  • C语言实现Hoare版快速排序(递归版)
  • git 避免输入用户名 密码 二进制/文本 文件冲突解决
  • [OpenWrt]RAX3000一根线实现上网和看IPTV
  • 最新50万字312道Java经典面试题52道场景题总结(附答案PDF)
  • ​html.parser --- 简单的 HTML 和 XHTML 解析器​
  • 赵传和源代码就是设计-UMLChina建模知识竞赛第4赛季第23轮
  • Leaflet.Graticule源码分析以及经纬度汉化展示
  • html 中vue3 的setup里调用element plus的弹窗 提示
  • 对话系统之解码策略(Top-k Top-p Temperature)
  • 《面向机器学习的数据标注规程》摘录
  • VGG(pytorch)
  • celery/schedules.py源码精读
  • 单片机上位机(串口通讯C#)
  • 初识Flask
  • JeecgBoot jmreport/queryFieldBySql RCE漏洞复现
  • 机器学习---模型评估
  • 【机器学习】应用KNN实现鸢尾花种类预测
  • ACL和NAT
  • MX6ULL学习笔记(十二)Linux 自带的 LED 灯
  • Qt容器QToolBox工具箱
  • 华为实训课笔记
  • 基于java 的经济开发区管理系统设计与实现(源码+调试)
  • 外包干了3个月,技术退步明显。。。
  • 详细教程 - 从零开发 Vue 鸿蒙harmonyOS应用 第一节
  • R语言对医学中的自然语言(NLP)进行机器学习处理(1)