【Redis】List 类型的介绍和常用命令

server/2025/2/1 9:30:36/

1. 介绍

Redis 中的 list 相当于顺序表,并且内部更接近于“双端队列”,所以也支持头插和尾插的操作,可以当做队列或者栈来使用,同时也存在下标的概念,不过和 Java 中的下标不同,Redis 支持负数下标,-1 表示倒数第一个元素,-2 表示倒数第二个元素,和 Java 中的 List 相同的是,列表中的元素是有序的,并且允许重复

 

2. 常用命令

命令

介绍

时间

rpush key value [value ...]

将一个或多个值插入到列表 key 的表尾(最右边)

O (k),k 是元素个数

lpush key value [value ...]

将一个或多个值插入到列表 key 的表头(最左边)

O (k),k 是元素个数

linsert key before

在列表的元素 pivot 之前插入元素 value

O (n),n 是 pivot 距离头的距离

after pivot value

在列表的元素 pivot 之后插入元素 value

O (n),n 是 pivot 距离头的距离

lrange key start end

获取列表指定范围内的元素

O (s+n),s 是 start 偏移量,n 是 start 到 end 的范围。

lindex key index

通过索引获取列表中的元素

O (n),n 是索引的偏移量

llen key

获取列表的长度

O (1)

lpop key

移除并返回列表 key 的头元素

O (1)

rpop key

移除并返回列表 key 的尾元素

O (1)

lrem key count value

count 大于 0 时,从左开始搜索,小于 0 时从右开始搜索,删除count 个值等于 value 的元素

O (k),k 是元素个数

ltrim key start end

保留 key 对应列表中指定区间 [start, end] 的元素

O (k),k 是元素个数

lset key index value

将列表 key 下标为 index 的元素的值设置为 value

O (n),n 是索引的偏移量。

blpop

lpop 的阻塞版本

O (1)

brpop

rpop 的阻塞版本

O (1)

3. 内部编码

在 Redis 3.2 之前主要采用linkedlistziplist,3.2 之后主要采用quicklist

linkedlist:双向链表

ziplist:经过特殊编码的连续内存块的顺序存储结构,它将多个元素紧凑地存储在一起,以节省内存空间

quicklist:它是一个双向链表,每个节点是一个 ziplist

4. 应用场景

  1. 消息队列

可以使用 lpush + brpop 来实现生产者-消费者模型队列

  1. 最新消息列表

用于展示最新的一些信息,如社交媒体平台上用户的最新动态、新闻网站的最新消息等,每当有新消息产生时,使用rpush命令将消息添加到 List 的尾部。要获取最新消息,通过lrange命令并设置合适的参数来获取 List 尾部的若干条消息。比如,在一个微博系统中,用户发布的微博可以存储在一个 List 结构中,通过获取 List 的尾部消息来展示用户关注的人发布的最新微博,可以方便地控制显示的消息数量,并且按照消息的发布顺序进行存储和展示,易于实现分页功能,以展示更多的消息


http://www.ppmy.cn/server/164031.html

相关文章

计算机网络 (61)移动IP

前言 移动IP(Mobile IP)是由Internet工程任务小组(Internet Engineering Task Force,IETF)提出的一个协议,旨在解决移动设备在不同网络间切换时的通信问题,确保移动设备可以在离开原有网络或子网…

react项目表格内容轮播,DataV-React轮播表的使用

项目中想要实现表格表头固定不动,表格行内容轮播呈现的效果,antd中的table无法实现,使用DataV-React轮播表来实现。 官网地址:介绍 | DataV-React 轮播表 | DataV-React 1. 安装 npm 安装 npm install jiaminghi/data-view-r…

JVM_类的加载、链接、初始化、卸载、主动使用、被动使用

①. 说说类加载分几步? ①. 按照Java虚拟机规范,从class文件到加载到内存中的类,到类卸载出内存为止,它的整个生命周期包括如下7个阶段: 第一过程的加载(loading)也称为装载验证、准备、解析3个部分统称为链接(Linking)在Java中数据类型分为基本数据类型和引用数据…

“大模型横扫千军”背后的大数据挖掘--浅谈MapReduce

文章目录 O 背景知识1 数据挖掘2 邦费罗尼原则3 TF.IDF4 哈希函数5 分布式文件系统 一、MapReduce基本介绍1. Map 任务2. 按键分组3. Reduce 任务4. 节点失效处理5.小测验:在一个大型语料库上有100个map任务和若干reduce任务: 二、基于MapReduce的基本运…

Canny 边缘检测

步骤 1.降噪 应用高斯滤波器,以平滑图像,滤除噪声。 边缘检测易受噪声影响,所以使用高斯滤波器平滑图像,降低噪声。 2.梯度 计算图像中每个像素点的梯度大小和方向。 计算大小 Sobel算子是一种常用的边缘检测滤波器&#xff…

【fly-iot飞凡物联】(20):2025年总体规划,把物联网整套技术方案和实现并落地,完成项目开发和课程录制。

前言 fly-iot飞凡物联专栏: https://blog.csdn.net/freewebsys/category_12219758.html 1,开源项目地址进行项目开发 https://gitee.com/fly-iot/fly-iot-platform 完成项目开发,接口开发。 把相关内容总结成文档,并录制课程。…

android studio生成jsk

JKS 文件(Java KeyStore)是 Android 开发中用于签名 APK 的密钥库文件。它包含用于签名的私钥和公钥,并保护其不被未授权使用。 在 Android 开发中,所有的 APK 文件在发布之前必须使用签名密钥进行签名: 调试签名&am…

【C++】类与对象(中)

🦄 个人主页: 小米里的大麦-CSDN博客 🎏 所属专栏: 小米里的大麦——C专栏_CSDN博客 🎁 代码托管: 小米里的大麦的Gitee仓库 ⚙️ 操作环境: Visual Studio 2022 文章目录 1. 类的6个默认成员函数传道解惑:Q1:e1——类…