【Redis】 关于列表类型

文章目录

  • 🍃前言
  • 🍀常见操作命令介绍
    • 🚩lpush
    • 🚩lpushx
    • 🚩rpush
    • 🚩rpushx
    • 🚩lrange
    • 🚩lpop
    • 🚩rpop
    • 🚩lindex
    • 🚩linsert
    • 🚩llen
    • 🚩lrem
    • 🚩ltrim
    • 🚩lset
  • 🌴阻塞版命令介绍
  • 🎄列表型的内部编码
  • 🎋使用场景
    • 🚩消息队列
  • ⭕总结

🍃前言

列表类型是⽤来存储多个有序的字符串,列表中的每个字符串称为元素(element),⼀个列表最多可以存储 2的32次方-1 个元素。

在 Redis 中,可以对列表两端插⼊(push)和弹出(pop),还可以获取指定范围的元素列表、获取指定索引下标的元素等。

列表是⼀种⽐较灵活的数据结构,它可以充当栈和队列的⻆⾊,在实际开发上有很多应⽤场景。

列表类型有以下特点:

  • 第⼀、列表中的元素是有序的,这意味着可以通过索引下标获取某个元素或者某个范围的元素列表

  • 第⼆、区分获取和删除的区别,获取与删除都会获得对应下标的值,但是删除会改变列表长度

  • 第三、列表中的元素是允许重复的

对列表类型有了一个基本的了解后,接下来我们来看看Redis中如何操作列表类型以及列表类型的内部编码与使用场景

🍀常见操作命令介绍

🚩lpush

将⼀个或者多个元素从左侧放⼊(头插)到 list 中。

语法:

lpush key element [element ...]

时间复杂度:

  • 只插⼊⼀个元素为O(1),插⼊多个元素为O(N), N 为插⼊元素个数.

返回值:

  • 插⼊后 list 的⻓度

在这里插入图片描述

🚩lpushx

在 key 存在时,将⼀个或者多个元素从左侧放⼊(头插)到 list 中。不存在,直接返回

语法:

lpushx key element [element ...]

时间复杂度:

  • 只插⼊⼀个元素为O(1),插⼊多个元素为O(N),N为插⼊元素个数.

返回值:

  • 插⼊后 list 的⻓度。

在这里插入图片描述

🚩rpush

将⼀个或者多个元素从右侧放⼊(尾插)到 list 中

语法:

rpush key element [element ...]

时间复杂度:

  • 只插⼊⼀个元素为 O(1),插⼊多个元素为 O(N), N 为插⼊元素个数.

返回值:

  • 插⼊后 list 的⻓度。

在这里插入图片描述

🚩rpushx

在 key 存在时,将⼀个或者多个元素从右侧放⼊(尾插)到 list 中。

语法:

rpushx key element [element ...]

时间复杂度:

  • 只插⼊⼀个元素为 O(1), 插⼊多个元素为 O(N), N 为插⼊元素个数.

返回值:

  • 插⼊后 list 的⻓度。

在这里插入图片描述

🚩lrange

获取从 start 到 end 区间的所有元素,左闭右闭。

语法:

lrange key start stop

时间复杂度:

  • O(N)

返回值:

  • 指定区间的元素

在这里插入图片描述

🚩lpop

从 list 左侧取出元素(即头删)

语法:

lpop key

时间复杂度:

  • O(1)

返回值:

  • 取出的元素或者nil。

在这里插入图片描述

🚩rpop

从 list 右侧取出元素(即尾删)。

语法:

rpop key

时间复杂度:

  • O(1)

返回值:

  • 取出的元素或者 nil

在这里插入图片描述

🚩lindex

获取从左数第 index 位置的元素

语法:

lindex key index

时间复杂度:

  • O(N)

返回值:

  • 取出的元素或者nil。

在这里插入图片描述

🚩linsert

在特定位置插入元素

语法:

linsert key <BEFORE | AFTER> pivot element

时间复杂度:

  • O(N)

返回值:

  • 插⼊后的 list ⻓度
    在这里插入图片描述

🚩llen

获取 list 的长度

语法:

llen key

时间复杂度:

  • O(1)

返回值:

  • list的⻓度。

在这里插入图片描述

🚩lrem

从左往右删除指定个数(count)的 value

语法:

lrem key count value

时间复杂度

  • O(k),k为list所存在value与count中的最小值

返回值:

  • 返回删除list的长度

在这里插入图片描述

🚩ltrim

删除除指定字段外的所有值

语法:

ltrim key start end

时间复杂度:

  • O(k),k为所删除list的长度

返回值:

  • ok

在这里插入图片描述

🚩lset

修改指定位置的值

语法:

lset key index value

时间复杂度:

  • O(1)

返回值:

  • ok

在这里插入图片描述

🌴阻塞版命令介绍

blpop 和 brpop 是 lpop 和 rpop 的阻塞版本,和对应⾮阻塞版本的作⽤基本⼀致,除了:

  • 在列表中有元素的情况下,阻塞和⾮阻塞表现是⼀致的。但如果列表中没有元素,⾮阻塞版本会理解返回 nil,但阻塞版本会根据 timeout,阻塞⼀段时间,期间 Redis 可以执⾏其他命令,但要求执⾏该命令的客⼾端会表现为阻塞状态。
  • 命令中如果设置了多个键,那么会从左向右进⾏遍历键,⼀旦有⼀个键对应的列表中可以弹出元素,命令⽴即返回。
  • 如果多个客⼾端同时多⼀个键执⾏ pop,则最先执⾏命令的客⼾端会得到弹出的元素。

接下来演示以下用法:

首先准备两个客户端
在这里插入图片描述

客户端1 准备一个列表数据如下

在这里插入图片描述

然后客户端2 使用阻塞版命令进行获取

在这里插入图片描述

获取玩列表元素后,再次进行获取:

首先使用非阻塞版本的 rpop 进行获取

在这里插入图片描述

其次使用阻塞版本的 brpop 进行获取,出现阻塞

在这里插入图片描述

接下来,使用客户端一,向队列添加元素:

在这里插入图片描述

我们就可以看到阻塞版命令与普通命令的差别了

🎄列表型的内部编码

列表类型的内部编码有两种:

  • ziplist(压缩列表):当列表的元素个数⼩于 list-max-ziplist-entries 配置(默认 512 个),同时列表中每个元素的⻓度都⼩于 list-max-ziplist-value 配置(默认 64 字节)时,Redis会选⽤ ziplist 来作为列表的内部编码实现来减少内存消耗。

  • linkedlist(链表):当列表类型⽆法满⾜ ziplist 的条件时,Redis 会使⽤ linkedlist 作为列表的内部实现

🎋使用场景

🚩消息队列

Redis 可以使⽤ lpush + brpop 命令组合实现经典的阻塞式⽣产者-消费者模型队列,⽣产者客⼾端使⽤ lpush 从列表左侧插⼊元素,多个消费者客⼾端使⽤ brpop 命令阻塞式地从队列中"争抢" 队⾸元素,通过多个客⼾端来保证消费的负载均衡和⾼可⽤性。

而且还可以通过用不同的键模拟频道的概念,不同的消费者可以通过brpop不同的键值,实现订阅不同频道的理念。

⭕总结

关于《【Redis】 关于列表类型》就讲解到这儿,感谢大家的支持,欢迎各位留言交流以及批评指正,如果文章对您有帮助或者觉得作者写的还不错可以点一下关注,点赞,收藏支持一下

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

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

相关文章

Python3 笔记:Python之禅

打开Python Shell&#xff0c;输入import this&#xff0c;按回车键运行程序。 Beautiful is better than ugly. 优雅胜于丑陋。 Explicit is better than implicit. 明确胜于含糊。 Simple is better than complex. 简单胜于复杂。

Ansible02-Ansible Modules模块详解

目录 写在前面4. Ansible Modules 模块4.1 Ansible常用模块4.1.1 Command模块4.1.2 shell模块4.1.3 scrpit模块4.1.4 file模块4.1.5 copy模块4.1.6 lineinfile模块4.1.7 systemd模块4.1.8 yum模块4.1.9 get_url模块4.1.10 yum_repository模块4.1.11 user模块4.1.12 group模块4.…

在C++中自定义命名空间,在命名空间中定义string变量,同时定义一个函数实现单词逆置

代码 #include <iostream> #include <cstring> using namespace std; namespace my_space {string s;void reverse(string s);//定义逆置函数 } using namespace my_space; void my_space::reverse(string s){int lens.size();int i0;int jlen-1;while(i<j){//…

设计模式17——模板方法模式

写文章的初心主要是用来帮助自己快速的回忆这个模式该怎么用&#xff0c;主要是下面的UML图可以起到大作用&#xff0c;在你学习过一遍以后可能会遗忘&#xff0c;忘记了不要紧&#xff0c;只要看一眼UML图就能想起来了。同时也请大家多多指教。 模板方法模式&#xff08;Temp…

买车是小米su7还是model3?这个AI在我这里“干掉了”百万车评人

作者 | 曾响铃 文 | 响铃说 43天交付1万辆新车&#xff01;雷军的微博一发&#xff0c;又把小米汽车推上了热搜。 自小米su7问世以来&#xff0c;天天刷屏。说不心动&#xff0c;那是假的&#xff0c;身边好几个朋友都按捺不住要下订一台了。 但真要买&#xff0c;还是忍不住…

容器组件:页面和自定义组件生命周期(HarmonyOS学习第五课)

页面和自定义组件生命周期 先明确自定义组件和页面的关系&#xff1a; 自定义组件:Component装饰的UI单元&#xff0c;可以组合多个系统组件实现U的复用。 页面:即应用的UI页面。可以由一个或者多个自定义组件组成&#xff0c;Entry装饰的自定义组件为贞面的入口组件&#xf…

5月26(信息差)

&#x1f30d; 珠峰登顶“堵车”后冰架断裂 5人坠崖 2人没爬上来&#xff01; 珠峰登顶“堵车”后冰架断裂 5人坠崖 2人没爬上来&#xff01; &#x1f384; Windows 11 Beta 22635.3646 预览版发布&#xff1a;中国大陆地区新增“微软电脑管家”应用 ✨ 成都限购解除即将满…

DOS学习-目录与文件应用操作经典案例-ren

新书上架~&#x1f447;全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我&#x1f446;&#xff0c;收藏下次不迷路┗|&#xff40;O′|┛ 嗷~~ 目录 一.前言 二.使用 三.案例 案例 1&#xff1a;重命名当前目录下的文件 案例 2&#xff1a…

Postman快捷功能-快速填写请求头

大家好&#xff0c;之前给大家分享关于 Postman 工具的基础使用&#xff0c;今天给大家介绍一个快捷功能&#xff0c;可以一定程度提高我们使用 Postman 工具的效率&#xff0c;在我们进行接口测试时&#xff0c;几乎每个接口都需要填写 Headers&#xff0c;且 Headers 中的参数…

【leetcode面试经典150题】-80. 删除有序数组中的重复项 II

【leetcode面试经典150题】-80. 删除有序数组中的重复项 II 1 题目介绍2 个人解题思路2.1 代码2.2 思路 3 官方题解 1 题目介绍 给你一个有序数组 nums &#xff0c;请你 原地 删除重复出现的元素&#xff0c;使得出现次数超过两次的元素只出现两次 &#xff0c;返回删除后数组…

一键接入大模型:One-Api本地安装配置实操,POSTMAN、APIFOX调用CURL

前言 最近准备学习一下 Semantic Kernel, OpenAI 的 Api 申请麻烦,所以想通过 One-api 对接一下国内的在线大模型,先熟悉一下 Semantic Kernel 的基本用法,本篇文章重点记录一下OneApi安装配置的过程。 讯飞星火有 3.5 模型的 200w 个人免费 token,可以拿来学习。 讯飞星…

推导2维镜像变换(Reflection Transform)的公式

我们知道2维的旋转变换公式为 Q ( cos ⁡ ( θ ) sin ⁡ ( θ ) − sin ⁡ ( θ ) cos ⁡ ( θ ) ) Q\left( \begin{matrix} \cos \left( \theta \right)& \sin \left( \theta \right)\\ -\sin \left( \theta \right)& \cos \left( \theta \right)\\ \end{matrix} \r…

UTF-8格式大统一:转码高效指南,彻底解决文件编码乱码问题!

文章目录 1 背景说明2 统一的好处3 对增量代码怎么进行统一4 对存量代码怎么进行统一4.1 指定单一文件夹&#xff0c;对里面的 .h .cpp 文件全转换4.2 指定单一文件夹&#xff0c;对里面的.h .cpp文件按需转换4.3 指定多文件夹&#xff0c;对里面的.h .cpp文件全部转换4.4 指定…

用数据,简单点!奇点云2024 StartDT Day数智科技大会,直播见

在充满挑战的2024&#xff0c;企业如何以最小化的资源投入和试错成本&#xff0c;挖掘新的增长机会&#xff0c;实现确定性发展&#xff1f; “简单点”是当前商业环境的应对策略&#xff0c;也是奇点云2024 StartDT Day的核心理念。 5月28日&#xff0c;由奇点云主办的2024 S…

RPA机器人流程自动化如何优化人力资源工作流程

人力资源部门在支持员工和改善整体工作环节方面扮演着至关重要的角色&#xff0c;但是在人资管理的日常工作中&#xff0c;充斥着大量基于规则的重复性任务&#xff0c;例如简历筛选、面试安排、员工数据管理、培训管理、绩效管理等&#xff0c;这些任务通常需要工作人员花费大…

Hive课程文档

基本语法 库操作 Hive和MySQL类似&#xff0c;提供了针对database的操作。 1)创建库&#xff1a; create database demo; 注意&#xff0c;每一个database在HDFS上都会对应一个目录&#xff0c;如果不指定&#xff0c;那么默认是放在/user/hive/warehouse/下。在Hive中&am…

消息回复及时,客户不流失!这个微信自动回复设置快快码住!

你是不是也遇到过由于回复不及时&#xff0c;导致客户流失的情况发生&#xff1f;或是好友申请太多&#xff0c;来不及通过&#xff1f; 别担心&#xff0c;试试个微管理系统&#xff0c;让你实现自动回复&#xff0c;提高回复效率&#xff01; 1、自动通过好友 当有新的好友…

5.23 Linux中超时检测方式+模拟面试

1.IO多路复用的原理&#xff1f; IO多路复用使得一个或少量线程资源处理多个连接的IO事件的技术。对于要处理的多个阻塞的IO操作&#xff0c;建立集合并存储它们的文件描述符&#xff0c;利用单个阻塞函数去监控集合中文件描述符事件到达的情况&#xff0c;&#xff08;如果到…

Python 全栈体系【四阶】(五十三)

第五章 深度学习 十二、光学字符识别&#xff08;OCR&#xff09; 2. 文字检测技术 2.3 DB&#xff08;2020&#xff09; DB全称是Differentiable Binarization&#xff08;可微分二值化&#xff09;&#xff0c;是近年提出的利用图像分割方法进行文字检测的模型。前文所提…

如何评价 OpenAI 最新发布支持实时语音对话的模型GPT-4o?OpenAI发完GTP-4o,国内大模型行业还有哪些机会?

文章目录 OpenAI发完GTP-4o&#xff0c;国内大模型行业还有哪些机会&#xff1f;详细了解一下OpenAI最新发布的支持实时语音对话的模型GPT-4o国内大模型如何寻找发展机会&#xff1f;想要发展技术必须要创新与追赶或许应用场景拓展也是一种出路产业生态构建 ChatGPT 问世才 17 …