前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >面试题42:介绍一下Redis中list类型的实现方式是什么?

面试题42:介绍一下Redis中list类型的实现方式是什么?

作者头像
爪哇缪斯
发布2023-05-09 21:42:59
1600
发布2023-05-09 21:42:59
举报
文章被收录于专栏:爪哇缪斯爪哇缪斯

【概述】

  • 适用场景:消息队列。
  • 它的特点:内部元素有序、重复,并且插入和删除很快O(1),但是查找却很慢O(n)。功能支持队列和栈操作。

【内部实现】

  • 列表对象的编码支持ziplist和linkedlist两种。

【ziplist】
  • ziplist编码列表对象,采用压缩列表实现。每个列表节点保存一个列表中的元素。比如我们插入a、b、c三个元素到列表中:
代码语言:javascript
复制
127.0.0.1:6379> RPUSH testlist a b c
(integer) 3

那么它的存储结构是这样的:


【linkedlist】

  • linkedlist编码列表对象,采用双向链表作为底层实现,每个列表节点保存一个列表中的元素。
  • 数据结构如下:

【编码转换规则】

  • 同时满足一下两个条件时,是ziplist类型,否则为linkedlist类型:
    • 条件1:列表中所有元素长度都小于66字节。
    • 条件2:列表中元素的个数小于512个。
  • 示例如下所示:
代码语言:javascript
复制
127.0.0.1:6379> RPUSH testlist a b c
(integer) 3
127.0.0.1:6379> OBJECT encoding testlist
"ziplist"
127.0.0.1:6379> RPUSH testlist 12345678901234567890123456789012345678901234567890123456789012345
(integer) 5
127.0.0.1:6379> OBJECT encoding testlist
"linkedlist"
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-10-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 爪哇缪斯 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 【概述】
    • 【ziplist】
    相关产品与服务
    云数据库 Redis
    腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档