Redis之List列表

news2025/1/13 15:29:47

目录

一.列表讲解

二.列表命令

三.内部编码

四.应用场景


Redis的学习专栏:http://t.csdnimg.cn/a8cvV

一.列表讲解

        列表类型是用来存储多个有序的字符串,如下所示,a、b、c、d、e五个元素从左到右组成了一个有序的列表,列表中的每个字符串称为元素(element),一个列表最多可以存储 2的32次方-1个元素。

在 Redis中,列表的元素是有序并且可重复的,可以对列表两端插入(push)和弹出(pop),还可以获取指定范围的元素列表获取指定索引下标的元素等。

列表是一种比较灵活的数据结构,它可以充当栈和队列的角色,在实际开发上有很多应用场景。

注:个人认为这是一个队列,并且最长负数下标。

二.列表命令

PUSH命令

        一次插入一个或者多个元素,如果想头插法,则LPUSH,尾插法:RPUSH  ;返回list长度。如果在末尾添加一个X,则表示,该列表必须存在,不存在则直接返回。

语法:PUSH key element [element ...]

POP命令

        出栈一个元素,也分LPOP和RPOP,两者就是左出和右出。注:redis6版本支持添加count 表示出栈多少元素

语法:POP  key [count]

LINDEX命令

        通过下标值获取元素值

语法: LINDEX key index

LINSERT 命令

        在指定元素的位置插入元素,before:前面;after:后面,而pivort表示元素。由于是L开通,所以找到元素是从左边开始找到第一个相同的元素。

语法:Linsert key <BEFORE | AFTER >PIVORT ELEMENT

LLEN

        直接获取list的长度

语法:LLEN key

LREM

        删除某个值value,并且设置删除的个数。

语法: LREM KEY COUNT  VALUE

COUNT:如果小于0,则从右开始删除;例:-1,则从右开始删除1

               如果大于0,则从左边开始删除

                如果等于0,则将列表的值全删了。

LTRIM命令

        对列表(List)进行修剪(Trim)操作的命令。它可以通过移除列表中的一部分元素

语法:LTRIM  key  start stop

LRANGE命令

        用于获取列表(List)中指定范围元素的命令,如果是 0 -1;则是全部元素

语法:LRANGE key start stop 

blpop命令和brpop

        这两个命令是lpop命令和rpop命令的升级版,为阻塞命令,执行之后,不影响你执行其他命令,他会耐心等待,一旦列表中有值了,就会出队列,返回值。当然也可以设置好等待时间timeout!如果涉及到了多个key,则按优先级弹出。如果多个客户端都执行此命令,谁先执行,谁先获取。

语法:BLPOP key [key ...] timeout

三.内部编码

        在 Redis 中,列表(List)是一种数据结构,用于存储多个有序的字符串元素。Redis 使用列表编码来存储列表数据,列表编码有两种形式:压缩列表(ziplist)双端链表(linkedlist)

1. 压缩列表(ziplist)

压缩列表采用情况:个数少于512,长度小于64字节。压缩列表是 Redis 中用于存储较小列表的编码方式,它采用紧凑的内存布局来减少内存使用。压缩列表的特点包括:

  • 紧凑存储: 压缩列表使用一块连续的内存来存储所有元素,每个元素由一个长度前缀和实际数据组成。
  • 灵活大小: Redis 会根据列表的长度和元素的大小动态选择是否使用压缩列表。
  • 快速操作: 压缩列表支持快速的插入和删除操作,因为它可以在不需要重新分配内存的情况下进行元素的添加和删除。

2. 双端链表(linkedlist)

双端链表是 Redis 中用于存储较大列表的编码方式,它具有以下特点:

  • 灵活存储: 双端链表由多个节点组成,每个节点包含一个元素和指向前后节点的指针。
  • 内存动态分配: 双端链表可以动态地增长或缩小,根据元素的数量和大小动态分配内存。
  • 灵活操作: 双端链表支持快速的插入和删除操作,尤其是在大列表中效率比较高。

注:redis版本不是采用linkedlist版本,而是采用链表+压缩列表的方式!整体是一个链表,每个结点是压缩列表。

四.应用场景

1.数据分类 

        统计班级的分数,例如需要存储每一个班级的学生信息(姓名、年龄、性别、分数)。虽然存储学生信息,我们可以使用Hash结构,但是学生分类到班级呢?

如果将学生信息设置好之后,根据学生的序号,放入列表当中!

2.消息队列

        使用Redis作为消息队列,之前我们讲解了两个命令,阻塞命令。blpop和brpop命令

如上图,生成者生产数据,消费者先执行,就拿元素!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1932152.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【连续四届EI检索|稳定ACM出版、EI检索|线上线下结合】2024年第五届医学人工智能国际学术会议(ISAIMS 2024,8月13-17)

第五届医学人工智能国际学术会议&#xff08;ISAIMS2024&#xff09;将于2024年8月13-17日于荷兰阿姆斯特丹自由大学召开&#xff0c;国内分会场将于2024年10月25-27日于中国武汉召开。 会议自2020年至今已经成功举办四届&#xff0c;吸引了来自海内外相关领域学者600余名。本届…

贪心算法(2024/7/16)

1合并区间 以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间&#xff0c;并返回 一个不重叠的区间数组&#xff0c;该数组需恰好覆盖输入中的所有区间 。 示例 1&#xff1a; 输入&#xff1a;inter…

MongoDB教程(七):mongoDB分片

&#x1f49d;&#x1f49d;&#x1f49d;首先&#xff0c;欢迎各位来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里不仅可以有所收获&#xff0c;同时也能感受到一份轻松欢乐的氛围&#xff0c;祝你生活愉快&#xff01; 文章目录 引言MongoDB 分…

Mysql数据库的概念及sql语法和规范+数据库的用户管理

一、数据库的概念 1.数据库&#xff1a;组织、管理、存储数据的仓库 2.数据库的管理系统&#xff08;DBMS&#xff09;&#xff1a;实现对数据有效组织&#xff0c;管理和存储的系统软件。 3.关系型数据库和非关系性数据库&#xff1a; 关系型数据库&#xff1a;mysql or…

神经网络概述

目录 1. 前馈神经网络(Feedforward Neural Networks, FNNs) 2. 卷积神经网络(Convolutional Neural Networks, CNNs) 3. 循环神经网络(Recurrent Neural Networks, RNNs) 4. 长短期记忆网络(Long Short-Term Memory, LSTM) 5. 门控循环单元(Gated Recurrent Unit…

MSPM0G3507——时钟主频拉到80MHZ

先点开使用时钟树 在配置时钟界面这样配置

【送书活动十期】从零开始node.js制作CLI工具

这篇博客的由来是源于工作中一个java项目的配置项是加密后的私钥&#xff0c;私钥是由其他项目中调用web3生成随机账号得到的&#xff0c;而加密方法只是简单在java项目中执行代码得到。这便导致两步操作有点割裂&#xff0c;需要有一个脚本来完成生成私钥和加密私钥&#xff0…

[Tensor学习]你不得不知道的知识点-切点-反转

wait...突然发现了一个错误&#xff1a; 在tensor里面只有size相同才允许相加&#xff0c; 如果想要相连接&#xff1a; PS: 如果tensor是多维的&#xff0c;比如说 a Tensor([1,2,3], [4,5,6]) 那么有 a[ : , :] a a[0,0] 1 a[ 第一维 &#xff0c;第二维] ...…

乘积量化pq:将高维向量压缩 97%

向量相似性搜索在处理大规模数据集时&#xff0c;往往面临着内存消耗的挑战。例如&#xff0c;即使是一个包含100万个密集向量的小数据集&#xff0c;其索引也可能需要数GB的内存。随着数据集规模的增长&#xff0c;尤其是高维数据&#xff0c;内存使用量会迅速增加&#xff0c…

MAC地址电脑的“身份证”

在电脑的世界里&#xff0c;每个设备都有一个独一无二的标识&#xff0c;就像我们的身份证号码一样。 这个标识被称为MAC地址&#xff08;Media Access Control Address&#xff09;&#xff0c;它是网络设备硬件的唯一识别码。 MAC地址由12个十六进制数字组成&#xff0c;通…

区块链资料

Quantstamp - Public Security Assessments smart-contract-sanctuary-bsc/contracts/mainnet at master tintinweb/smart-contract-sanctuary-bsc GitHub https://github.com/slowmist/Cryptocurrency-Security-Audit-Guide/blob/main/README_CN.md sFuzz: 高效自适应的智…

ArkUI组件——循环控制/List

循环控制 class Item{name: stringprice:number}private items:Array<Item> [new Item("A0",2399),new Item("BE",1999),new Item("Ro",2799)] ForEach(this.items,(item:Item) > {})List组件 列表List是一种复杂的容器&#xff0c;…

小程序里面使用vant ui中的vant-field组件,如何使得输入框自动获取焦点

//.wxml <van-fieldmodel:value"{{ userName }}"placeholder"请输入学号"focus"{{focusUserName}}"/>// .js this.setData({focusUserName: true});vant-field

postgresql删除用户

背景 **角色与用户**&#xff1a;在 PostgreSQL 中&#xff0c;用户和组的概念是通过“角色”来统一实现的。角色可以有登录权限&#xff08;在这种情况下&#xff0c;它们通常被称为“用户”&#xff09;&#xff0c;也可以没有&#xff08;在这种情况下&#xff0c;它们通常用…

网络请求之代理proxy

为什么要用代理呢&#xff1f;这个就涉及到安全问题了&#xff0c;你要是用一个IP频繁的访问人家网站&#xff0c;这不就是在搞事情么&#xff0c;人家网站肯定得把你的IP禁掉。所以我们爬虫的时候就得经常换IP&#xff0c;就是拿别人的IP不同人的IP访问网站去爬取数据。 我们…

AQS源码解析(ReentrantLock)

什么是AQS:Juc中的大多数同步器都是围绕着一些相同的基础行为&#xff0c;比如等待队列&#xff0c;条件队列&#xff0c;共享&#xff0c;独占获取变量这些行为&#xff0c;抽象出来就是基于AQS&#xff08;AbstractQueuedSynchronizer&#xff09;实现的。所以可以把AQS看成这…

昇思学习打卡-18-LLM原理与实践/MindNLP ChatGLM-6B StreamChat

文章目录 模型介绍技术特点运行效果 模型介绍 ChatGLM-6B模型是一个开源的、支持中英双语的对话语言模型&#xff0c;由清华大学和智谱AI联合研发。 技术特点 模型量化技术&#xff1a;ChatGLM-6B结合了模型量化技术&#xff0c;使得用户可以在消费级的显卡上进行本地部署。…

C++动态内存的管理

今天来分享C动态内存管理相关知识&#xff0c;闲言勿谈&#xff0c;直接上干货。 1. 动态内存的开辟和销毁(new和delete) (1)前置知识&#xff1a;我们知道c语言有malloc和calloc和realloc三个函数可以进行动态的开辟内存&#xff0c;那么它们有什么区别呢&#xff1f;首先是…

Module2 DRC Basics

材料链接 calibre_rule_writing_2007 - 道客巴巴https://www.doc88.com/p-330763936895.html Calibre DRC介绍 Calibre nmDRC流程 找寻,查看,纠正DRC冲突的一个完整的过程: 从Layout输入,加上svrf文件,一起输入进nmDRC软件; 输出DRC result数据,summary report,tr…

【经验分享】关于静态分析工具排查 Bug 的方法

文章目录 编译器的静态分析cppcheck安装 cppcheck运行 cppcheck 程序员的日常工作&#xff0c;不是摸鱼扯皮&#xff0c;就是在写 Bug。虽然这是一个梗&#xff0c;但也可以看出&#xff0c;程序员的日常一定绕不开 Bug。而花更少的时间修复软件中的 Bug&#xff0c;且不引入新…