Redis之List列表

目录

一.列表讲解

二.列表命令

三.内部编码

四.应用场景


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.mzph.cn/pingmian/48417.shtml

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

相关文章

标准IO中fopen函数返回的FILE*指针的存储位置

程序的内存分配&#xff1a; 一个由C/C编译的程序占用的内存分为以下几个部分 1、栈区&#xff08;stack&#xff09;&#xff1a;由编译器自动分配释放 &#xff0c;存放函数的参数值&#xff0c;局部变量的值等。其 操作方式类似于数据结构中的栈。 …

软链接跟硬链接有什么区别

‌软连接和‌硬连接是‌linux文件系统中的两种不同类型的链接&#xff0c;它们的主要区别在于&#xff1a; 本质不同&#xff1a;硬连接是同一文件的不同名称&#xff0c;而软连接则指向另一个文件或目录的路径。硬连接与原始文件共享相同的inode信息&#xff0c;因此它们指向同…

微软史诗级的蓝屏

本周经历了微软的蓝屏&#xff0c;一直到周末还在加班处理公司的问题。 个人终端受到的影响较大&#xff0c;服务器上也受到了影响。因为蓝屏的事情导致不少麻烦&#xff0c;据同事说因为蓝屏的问题&#xff0c;MGH 的手术安排也受到了影响。 目前我们也在着手处理有部署 Wind…

【Apollo学习笔记】—— Cyber RT之创建组件, test ok

0. 前置知识 这部分内容详见第三章:Component组件认知与实践https://apollo.baidu.com/community/article/1103 0.1 什么是 Component Apollo 的 Cyber RT 框架是基于组件(component)概念来构建的。每个组件都是 Cyber RT 框架的一个特定的算法模块, 处理一组输入并产生其…

Leetcode 3227. Vowels Game in a String

Leetcode 3227. Vowels Game in a String 1. 解题思路2. 代码实现 题目链接&#xff1a;3227. Vowels Game in a String 1. 解题思路 这一题稍微分析一下之后就会发现&#xff0c;这个游戏有且只有一种情况Bob才能够赢&#xff0c;即原始字符串当中不存在元音字母的情况&…

算法:优先级队列(堆)

目录 题目一&#xff1a;最后一块石头重量 题目二&#xff1a;数据流中的第 K 大元素 题目三&#xff1a;前 K 个高频单词 题目四&#xff1a;数据流的中位数 题目一&#xff1a;最后一块石头重量 有一堆石头&#xff0c;每块石头的重量都是正整数。 每一回合&#xff0c…

基于SpringBoot+Vue的网吧管理系统(带1w+文档)

基于SpringBootVue的网吧管理系统(带1w文档) 基于SpringBootVue的网吧管理系统(带1w文档) 网吧管理系统&#xff0c;为了随时随地查看网吧管理信息提供了便捷的方法&#xff0c;更重要的是大大的简化了管理员管理网吧的方式方法&#xff0c;更提供了其他想要了解网吧管理信息及…

Unity如何使摄像机视锥体外的物体不被剔除

在默认情况下&#xff0c;Unity在渲染场景时会剔除掉摄像机视椎体以外的所有物体&#xff0c;这就会导致某些特殊情况下&#xff0c;我们希望显示在场景中的物体反而被剔除了&#xff0c;比如用Shader制作顶点动画时&#xff0c;如果物体本身的位置在摄像机以外&#xff0c;而顶…

【云原生】Prometheus 服务自动发现使用详解

目录 一、前言 二、Prometheus常规服务监控使用现状​​​​​​​ 2.1 Prometheus监控架构图 2.2 Prometheus服务自动发现的解决方案 三、Prometheus服务自动发现介绍 3.1 什么是Prometheus服务自动发现 3.2 Prometheus自动服务发现策略 3.3 Prometheus自动服务发现应用…

SQL39道常见题型

SQL1 查询所有列 现在运营想要查看用户信息表中所有的数据&#xff0c;请你取出相应结果。 select * from user_profile 结果&#xff1a; SQL2 查询多列 还是上面那个输入&#xff0c;题目换成&#xff1a;现在运营同学想要用户的设备id对应的性别、年龄和学校的数据&#…

Springboot同时支持http和https访问

springboot默认是http的 一、支持https访问 需要生成证书&#xff0c;并配置到项目中。 1、证书 如果公司提供&#xff0c;则直接使用公司提供的证书&#xff1b; 如果公司没有提供&#xff0c;也可自己使用Java自带的命令keytool来生成&#xff1a; &#xff08;1&#x…

Flink History Server配置

目录 问题复现 History Server配置 HADOOP_CLASSPATH配置 History Server配置 问题修复 启动flink集群 启动Histroty Server 问题复现 在bigdata111上执行如下命令开启socket&#xff1a; nc -lk 9999 如图&#xff1a; 在bigdata111上执行如下命令运行flink应用程序 …

windows下玩转DockerDesktop--学习笔记

视频链接 Window下玩转Docker Desktop_哔哩哔哩_bilibili 安装ubuntu 安装wsl 网站 安装 WSL | Microsoft Learn winr 输入powershell&#xff0c;输入 wsl --install 通过修改Hosts解决国内Github经常抽风访问不到 网址 maxiaof/github-hosts: 通过修改Hosts解决国内G…

手动构建线性回归(PyTorch)

import torch from sklearn.datasets import make_regression import matplotlib.pyplot as plt import random #1.构建数据 #构建数据集 def create_dataset():x,y,coefmake_regression(n_samples100,n_features1,random_state0,noise10,coefTrue,bias14.5)#将构建数据转换为张…

录入学生信息

定义学生类Student&#xff0c;包含姓名&#xff0c;年龄&#xff0c;性别&#xff0c;分数四个属性&#xff0c;提供一个用于学员信息输出的方法info(self)。编写测试代码&#xff0c;使用循环录入5位学生的信息&#xff0c;由于录入的学生信息中间使用“#”进行分隔&#xff…

Spark学习之SparkSQL

SparkSQL 1、SparkSql初识案例 :WordCount spark sql处理数据的步骤1、读取数据源2、将读取到的DF注册成一个临时视图3、使用sparkSession的sql函数&#xff0c;编写sql语句操作临时视图&#xff0c;返回的依旧是一个DataFrame4、将结果写出到hdfs上 import org.apache.spark.…

C++基础语法:STL之容器(6)--序列容器中的forward_list

前言 "打牢基础,万事不愁" .C的基础语法的学习 引入 序列容器的学习.以<C Prime Plus> 6th Edition(以下称"本书")内容理解 本书中容器内容不多只有几页.最好是有数据结构方面的知识积累,如果没有在学的同时补上 上一篇C基础语法:链表和数据结…

Linux系统命令:监控 CPU 性能的工具mpstat详解

目录 一、概述 二、语法和使用 1、基本语法 2、常用选项 三、安装 mpstat 1、Debian&#xff08;如 Ubuntu&#xff09;的系统安装 2、CentOS 或 Fedora系统的安装 &#xff08;1&#xff09;安装指令 &#xff08;2&#xff09;安装操作 3、使用 四、示例 1. 查看…

【人工智能】Python实现文本转换为语音:使用gTTS库实现

&#x1f525; 个人主页&#xff1a;空白诗 文章目录 一、引言二、准备工作三、使用gTTS实现文本转换为语音详细步骤 四、人工智能与TTS技术五、总结 一、引言 文本转换为语音&#xff08;Text-to-Speech&#xff0c;简称TTS&#xff09;技术是人工智能的重要组成部分&#xf…

Unity UGUI 之 Canvas画布

本文仅作学习笔记与交流&#xff0c;不作任何商业用途 本文包括但不限于unity官方手册&#xff0c;唐老狮&#xff0c;麦扣教程知识&#xff0c;引用会标记&#xff0c;如有不足还请斧正 1.UGUI是什么 首先官方手册导向了这两个连接&#xff0c;里面是ugui的基本教程 帆布 |U…