美文网首页
压缩列表

压缩列表

作者: 我要尝鲜 | 来源:发表于2018-07-15 21:19 被阅读0次

压缩列表(ziplist)是列表键和哈希键的底层实现之一。当一个列表键只包含少量列表项,并且每个列表项要么就是小整数值,要么就是长度比较短的字符串,那么redis就会使用压缩列表来做列表建的底层实现。

压缩列表的结构

zlbytes zltail zllen entry1 entry2 ... entryN zlend
属性 类型 长度 用途
zlbytes uint32_t 4字节 记录整个压缩列表占用的内存字节数:在对压缩列表进行内存重分配,或者计算zlend的位置时使用
zltail uint32_t 4字节 记录压缩表表尾节点距离压缩列表的起始地址有多少字节:通过整个偏移量,程序无需遍历整个压缩列表皆可以确定表尾节点的地址
zllen uint16_t 2字节 记录了压缩列表包含的节点数量
entryX 列表节点 不定 压缩列表包含的各个节点
zlend uint8_t 1字节 特殊值0xFF(十进制255),用于标记压缩列表的末端

压缩列表节点的构成

previous_entry_length encoding content

previous_entry_length:以字节为单位,记录了压缩列表中前一个节点的长度。
因为节点的previous_entry_length属性记录了前一个节点的长度,所以程序可以通过指针运算,根据当前节点的起始地址来计算出前一个节点的起始地址。
encoding:记录了节点content属性所保存数据的类型以及长度
content:负责保存节点的值,可以是一个字节数组或者整数。

总结

压缩列表是一种为节约内存而开发的顺序型数据结构。
压缩列表被用作列表建和哈希键的底层实现之一。
压缩列表可以包含多个节点,每个节点可以保存一个字节数组或者整数值。

相关文章

  • 7 压缩列表

    压缩列表(ziplist)是列表键和哈希键的底层实现之一。 7.1 压缩列表的构成 压缩列表是Redis为了节约内...

  • Redis数据结构与对象——压缩列表

    压缩列表(ziplist)是列表和哈希键的底层实现之一。 1 压缩列表的构成 压缩列表是Redis节约成本而开发,...

  • redis ziplist

    压缩列表 压缩列表(ziplist)是列表键和哈希键的底层实现之一。 当一个列表键只包含少量列表项, 并且每个列表...

  • 快速整透Redis中的压缩列表到底是个啥

    压缩列表简介 压缩列表(ziplist)是由一个连续内存组成的顺序型数据结构。一个压缩列表可以包含任意多个节点,每...

  • 06.压缩列表

    1.简介: 压缩列表: 压缩列表是列表键和哈希键的底层实现之一,当一个列表键只包含少量的列表项, 并且每个列表...

  • 压缩列表

    zipList是list和hash的底层实现之一。 即当list包含少量的列表项或者小整数。要么就是长度比较短的字...

  • 压缩列表

    压缩列表(ziplist)是列表键和哈希键的底层实现之一。当一个列表键只包含少量列表项,并且每个列表项要么就是小整...

  • 压缩列表

    构成 压缩列表是 Redis 为了节约内存而开发的, 由一系列特殊编码的连续内存块组成的顺序型(sequentia...

  • 7.压缩列表

    压缩列表 1. 压缩列表的构成 压缩列表是Redis为了节约内存而开发,是由一系列特殊编码的连续内存块组成的顺序型...

  • 8.6 有序集合对象

    有序集合对象的编码可以是ziplist或者skiplistziplist编码的压缩列表对象使用压缩列表作为底层实现...

网友评论

      本文标题:压缩列表

      本文链接:https://www.haomeiwen.com/subject/eucmpftx.html