当前位置: 首页 > news >正文

redis:list列表命令和内部编码

在这里插入图片描述

个人主页 : 个人主页
个人专栏 : 《数据结构》 《C语言》《C++》《Linux》《网络》 《redis学习笔记》

文章目录

  • 前言
  • 命令
    • LPUSH 和 LPUSHX
    • LRANGE
    • RPUSH 和 RPUSHX
    • LPOP 和 RPOP
    • LINDEX
    • LINSERT
    • LLEN
    • LREM
    • LTRIM
    • LSET
    • 阻塞版命令
      • BLPOP 和 BRPOP
  • 内部编码
  • 总结


前言

列表类型是用来存储多个有序的字符串,列表中的每个字符串称为元素;列表是一种灵活的数据结构,可以充当栈和队列。

下图为列表两端插入和弹出操作
在这里插入图片描述
下图为列表的获取和删除等操作
在这里插入图片描述
注意:
约定最左侧元素下标是0;
redis的下标支持负数下标;
list 并非是一个简单的数组,而是更接近于双端队列;

列表类型的特点:

  • 列表中的元素是有序的,有序表示元素的顺序很重要。相同元素不同顺序是不同的列表
  • 列表中的元素是允许重复的

命令

LPUSH 和 LPUSHX

将一个或者多个元素从左侧(头插)放入到list中

LPUSH key element [element … ]

返回值:插入后list的长度
时间复杂度:O(N),N为插入元素个数

在这里插入图片描述


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

LPUSHX key element [element … ]

返回值:插入后list的长度
时间复杂度:O(N),N为插入元素个数

在这里插入图片描述


注意:
如果key已经存在,并且key对应的value类型,不是list,此时lpush命令就会报错
在这里插入图片描述
redis 中所有的这些各种数据类型的操作,都是类似的效果


LRANGE

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

LRANGE key start stop

返回值:指定区间的元素
时间复杂度:O(N)

在这里插入图片描述

redis并没有提供 rrange 命令


注意:
redis处理下标,是直接尽可能的获取到给定区间的元素;如果给定区间非法,比如超出下标就会尽可能的获取对应的内容。
在这里插入图片描述


RPUSH 和 RPUSHX

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

RPUSH key element [ element … ]

返回值:插入后list的长度
时间复杂度:O(N),N为插入元素个数

在这里插入图片描述


在 key 存在时,将一个或多个元素从右侧放入(尾插)到list中,不存在,直接返回

RPUSHX key element [ element … ]

返回值:插入后list的长度
时间复杂度:O(N),N为插入元素个数
在这里插入图片描述


LPOP 和 RPOP

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

LPOP key

返回值:取出的元素或者nil
时间复杂度:O(1)

在这里插入图片描述


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

RPOP key

返回值:取出的元素或者nil
时间复杂度:O(1)

在这里插入图片描述


注意:
redis中的list是一个双端队列,从两头插入/删除元素都是O(1);搭配使用 rpush 和 lpop 就相当于 队列,搭配使用 rpush 和 rpop 就相当于 栈。


LINDEX

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

LINDEX key index

返回值:取出的元素 或者 nil
时间复杂度:O(N),N为list的长度

在这里插入图片描述


LINSERT

在特定位置插入元素

LINSERT key < BEFORE | AFTER> pivot element

返回值:插入后的list长度
时间复杂度:O(N),N为list的长度

在这里插入图片描述


注意:
如果要插入的列表中,基准值存在多个,怎么办?insert进行插入时,要根据基准值,找到对应的位置。从左往右找,找到第一个符合基准值的位置即可。

在这里插入图片描述


LLEN

获取 list 长度

LLEN key

返回值:list的长度
时间复杂度:O(1)

在这里插入图片描述


LREM

移除list中指定数量的与给定值相等的元素

LREM key count value

返回值:被移除元素的数量
时间复杂度:O(N),N为list的长度

  • count > 0:从列表左侧开始,移除与 value 相等的最多 count个元素
  • count < 0:从列表尾部开始,移除与 value 相等的最多 count个元素
  • count = 0:移除列表中所有与value相等的元素

在这里插入图片描述


LTRIM

保留 start 和 stop 之间区间内的元素(区间两边的元素直接删除)

LTRIM key start stop

返回值:成功,返回“OK”
时间复杂度:O(N),N为被移除的元素数量
在这里插入图片描述


注意:
redis6 开始支持 ACL(access control list 访问控制列表),也就是权限。
redis由很多命令,acl把每个命令都打上标签,管理员就可以给每个redis用户配置不同的权限(允许 该用户 可以执行那些标签对应的命令)


LSET

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

LSET key index element

返回值:成功,返回“OK”;失败,返回错误信息
时间复杂度:O(N),N为列表的长度
在这里插入图片描述


阻塞版命令

blpop 和 brpop 是 lpop 和 rpop 的阻塞版本。

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

redis中的list也相当于 阻塞队列 一样,线程安全是通过单线程模型支持的;阻塞,则只支持"队列为空"的情况,不考虑"队列满了"


BLPOP 和 BRPOP

BLPOP key [key …] timeout

BRPOP key [key …] timeout

如果这些list有任何一个非空,blpop都能够把这里的元素给获取到,立即返回;
如果这些list都为空,此时需要阻塞等待,等待其它客户端向这些list插入元素;
可以指定超时时间,单位是 秒 (redis 6 超时时间允许设定为小数;redis 5 超时时间要是整数)

brpop效果和blpop类似

  • 针对一个非空的列表进行操作
    在这里插入图片描述
    返回结果相当于一个pair(二元组),一方面告诉我们当前的数据来自哪个key,一方面告诉我们取到的数据是什么
  • 针对一个空的列表进行操作
    在这里插入图片描述
  • 针对多个key进行操作
    在这里插入图片描述

内部编码

之前list类型的内部编码实现有两种:

  • ziplist(压缩列表):当列表的元素个数小于 list-max-ziplist-entries 配置,同时列表中每个元素的长度都小于 list-max-ziplist-value 配置时,redis会选用ziplist来作为列表内部编码实现来减小内存消耗
  • linkedlist(链表):当列表类型无法满足ziplist的条件时,redis会使用linkedlist作为列表内部实现

现在list类型内部使用quicklist实现
quicklist是一个双向链表,但它的节点是压缩列表;每个quicklist节点都包含一个ziplist,ziplist中存储了list类型的数据元素。这种设计即保持了双向链表的插入和删除优势,又通过压缩列表提高了内存利用率

在这里插入图片描述


总结

以上就是我的redis学习笔记

在这里插入图片描述

相关文章:

redis:list列表命令和内部编码

个人主页 &#xff1a; 个人主页 个人专栏 &#xff1a; 《数据结构》 《C语言》《C》《Linux》《网络》 《redis学习笔记》 文章目录 前言命令LPUSH 和 LPUSHXLRANGERPUSH 和 RPUSHXLPOP 和 RPOPLINDEXLINSERTLLENLREMLTRIMLSET阻塞版命令BLPOP 和 BRPOP 内部编码总结 前言 列…...

.Net Core Configuration用法

//在应用程序的任何地方注入 IConfiguration 来访问配置数据。ASP.NET Core 默认会加载 appsettings.json 文件 IConfiguration _configuration builder.Configuration; string connectionString _configuration["ConnectionStrings:SqlServerConnection"]; Hel…...

分享一些企业选择管理顾问公司的成功经验

为了在激烈的市场竞争中脱颖而出&#xff0c;许多企业开始寻求外部专业力量的支持&#xff0c;其中&#xff0c;企业管理顾问公司以其专业的知识、丰富的经验和独到的见解&#xff0c;成为了众多企业的得力助手。本文将分享一些企业在选择企业管理顾问公司过程中的成功经验&…...

「Qt Widget中文示例指南」如何实现窗口嵌入?

Qt 是目前最先进、最完整的跨平台C开发工具。它不仅完全实现了一次编写&#xff0c;所有平台无差别运行&#xff0c;更提供了几乎所有开发过程中需要用到的工具。如今&#xff0c;Qt已被运用于超过70个行业、数千家企业&#xff0c;支持数百万设备及应用。 本文中的示例主要演…...

企业CRM选型必看:2024年最佳CRM系统排行

企业用户在选择CRM系统时&#xff0c;不仅要考虑系统的功能性、可定制性&#xff0c;还要考虑其与现有工具的集成能力以及价格。此外&#xff0c;在2024年&#xff0c;越来越多的企业用户会把CRM厂商的AI能力列入考察范畴。 本文分析整理2024年最佳CRM系统排行榜&#xff0c;从…...

SQL入门的基础知识

思考 无论是干任何语言或者其他方向的开发&#xff0c;都会和我们的SQL去进行打交道 总结 学习SQL的原因&#xff1a;后面的实战案例需要用SQL&#xff0c;SQL是开发人员的必备技能 现在只需要学到满足后续案例需要&#xff0c;即简单增删改查&#xff0c;做一个入门即可 1.…...

JS渗透(安全)

JS逆向 基本了解 作用域&#xff1a; 相关数据值 调用堆栈&#xff1a; 由下到上就是代码的执行顺序 常见分析调试流程&#xff1a; 1、代码全局搜索 2、文件流程断点 3、代码标签断点 4、XHR提交断点 某通js逆向结合burp插件jsEncrypter 申通快递会员中心-登录 查看登录包…...

淘宝扭蛋机小程序,功能优势分析

随着潮玩文化的影响&#xff0c;扭蛋机作为潮玩的鼻祖&#xff0c;又再次成为了大众的“宠儿”。扭蛋机通过与多种IP结合&#xff0c;创造出各种元素的商品&#xff0c;为大众带来娱乐、收藏的新方式。我国潮玩市场规模正在大幅度的增长&#xff0c;将达到千亿元&#xff0c;发…...

Redis 数据备份与恢复

Redis 数据备份与恢复 引言 Redis 作为一种高性能的键值存储数据库,在许多应用场景中扮演着重要的角色。然而,数据的安全性是任何数据库系统都需要关注的问题。为了确保数据的安全和完整性,定期进行数据备份和掌握恢复策略是至关重要的。本文将详细介绍 Redis 数据备份与恢…...

CentOS9 Stream 设置禁用IPV6

CentOS9 Stream 设置禁用IPV6 方法 1: 修改 sysctl 配置方法 2: 使用 NetworkManager方法 3: 禁用内核参数验证 IPv6 是否禁用 在 CentOS 9 Stream 中&#xff0c;您可以通过以下步骤禁用 IPv6&#xff1a; 方法 1: 修改 sysctl 配置 编辑 sysctl 配置文件&#xff1a; 打开 /…...

C语言 | Leetcode C语言题解之第530题二叉搜索树的最小绝对差

题目&#xff1a; 题解&#xff1a; void dfs(struct TreeNode* root, int* pre, int* ans) {if (root NULL) {return;}dfs(root->left, pre, ans);if (*pre -1) {*pre root->val;} else {*ans fmin(*ans, root->val - (*pre));*pre root->val;}dfs(root->…...

【系统设计】高效的分布式系统:使用 Spring Boot 和 Kafka 实现 Saga 模式

在现代分布式系统中&#xff0c;管理跨多个服务的长事务至关重要。传统的分布式事务解决方案往往面临性能瓶颈和复杂性问题&#xff0c;而 Saga 模式 作为一种灵活高效的解决方案&#xff0c;逐渐受到开发者的青睐。本文将探讨如何利用 Spring Boot 和 Kafka 实现 Saga 模式&am…...

蓝桥杯 python day01 第一题

1. 确定字符串是否包含唯一字符 确定字符串是否包含唯一字符 题目描述 实现一个算法来识别一个字符串的字符是否是唯一的&#xff08;忽略字母大小写&#xff09;。 若唯一&#xff0c;则输出YES&#xff0c;否则输出NO。 输入描述 输入一行字符串&#xff0c;长度不超过…...

10款好用的win10录屏软件带你体验专业录屏。

其实win10系统的设备上有自带的录屏功能&#xff0c;还有powerpoint里面也有录屏工具可以使用。如果有朋友觉得里面的功能并不能够满足自己的录屏需求的话&#xff0c;可以用专门的录屏软件来完成。比如我最近找到的这4款工具&#xff0c;录制的视频效果好&#xff0c;操作还方…...

2025浙江省考报名流程详细教程

2025年浙江省考报名马上就要开始了&#xff0c;有想要参加浙江省考的同学&#xff0c;可以提前看一下报名流程&#xff0c;和报名照要求。 报名时间&#xff1a;11月6日9时一11月11日17时 南核时间&#xff1a;11月6日9时一11月13日17时 缴费时间&#xff1a;11月14日9时一11月…...

unity3d——关于GetComponent<T>()

先看代码&#xff1a; TankBaseObj obj other.GetComponent<TankBaseObj>();if(obj ! null){//说明是坦克打到坦克 受伤处理 固定不会受伤 移动的会受伤obj.Wound(fatherObj);} TankBaseObj 是一个基类 wound是一个虚函数 子类已经重新实现 当你的游戏对象依附…...

Spring 框架中常见的注解(Spring、SpringMVC、SpringBoot)

1. Spring 中常见注解 还有Recourse&#xff1a;相当于AutowiredQualifier Value : 用于将配置文件中的值注入到Bean的字段中。 Bean : 用于在配置类中声明一个Bean。 Lazy : 用于延迟加载Bean。 2. SpringMVC 中常见注解 还有GetMapping PostMapping PutMapping DeleteMapp…...

Hms?: 1渗透测试

靶机&#xff1a;Hms?: 1 Hms?: 1 ~ VulnHub 攻击机&#xff1a;kail linux 2024 主机扫描阶段发现不了靶机&#xff0c;所以需要按DriftingBlues2一样手动配置网卡 1,将两台虚拟机网络连接都改为NAT模式&#xff0c;并查看靶机的MAC地址 2&#xff0c;攻击机上做主机扫描发现…...

1、Qt6 Quick 简介

一、Qt6 Quick 简介 1、Qt Quick简介 Qt Quick 是 Qt 6 中使用的用户界面技术的总称。它是在 Qt 4 中引入的&#xff0c;现在在 Qt 6 中进行了扩展。Qt Quick 本身是几种技术的集合&#xff1a; QML——用户界面标记语言JavaScript - 动态脚本语言Qt C - 高度可移植的增强型…...

大模型论文集-20241103

Investigating the catastrophic forgetting in multimodal large language models 研究问题 本文探讨了多模态大型语言模型&#xff08;MLLMs&#xff09;在学习新任务时的灾难性遗忘现象。研究者关注于在添加新数据集后&#xff0c;模型是否能够保留之前学到的知识而不忘记…...

盘古信息PCB行业解决方案:以全域场景重构,激活智造新未来

一、破局&#xff1a;PCB行业的时代之问 在数字经济蓬勃发展的浪潮中&#xff0c;PCB&#xff08;印制电路板&#xff09;作为 “电子产品之母”&#xff0c;其重要性愈发凸显。随着 5G、人工智能等新兴技术的加速渗透&#xff0c;PCB行业面临着前所未有的挑战与机遇。产品迭代…...

LLM基础1_语言模型如何处理文本

基于GitHub项目&#xff1a;https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken&#xff1a;OpenAI开发的专业"分词器" torch&#xff1a;Facebook开发的强力计算引擎&#xff0c;相当于超级计算器 理解词嵌入&#xff1a;给词语画"…...

2023赣州旅游投资集团

单选题 1.“不登高山&#xff0c;不知天之高也&#xff1b;不临深溪&#xff0c;不知地之厚也。”这句话说明_____。 A、人的意识具有创造性 B、人的认识是独立于实践之外的 C、实践在认识过程中具有决定作用 D、人的一切知识都是从直接经验中获得的 参考答案: C 本题解…...

使用Matplotlib创建炫酷的3D散点图:数据可视化的新维度

文章目录 基础实现代码代码解析进阶技巧1. 自定义点的大小和颜色2. 添加图例和样式美化3. 真实数据应用示例实用技巧与注意事项完整示例(带样式)应用场景在数据科学和可视化领域,三维图形能为我们提供更丰富的数据洞察。本文将手把手教你如何使用Python的Matplotlib库创建引…...

NXP S32K146 T-Box 携手 SD NAND(贴片式TF卡):驱动汽车智能革新的黄金组合

在汽车智能化的汹涌浪潮中&#xff0c;车辆不再仅仅是传统的交通工具&#xff0c;而是逐步演变为高度智能的移动终端。这一转变的核心支撑&#xff0c;来自于车内关键技术的深度融合与协同创新。车载远程信息处理盒&#xff08;T-Box&#xff09;方案&#xff1a;NXP S32K146 与…...

DingDing机器人群消息推送

文章目录 1 新建机器人2 API文档说明3 代码编写 1 新建机器人 点击群设置 下滑到群管理的机器人&#xff0c;点击进入 添加机器人 选择自定义Webhook服务 点击添加 设置安全设置&#xff0c;详见说明文档 成功后&#xff0c;记录Webhook 2 API文档说明 点击设置说明 查看自…...

2025年渗透测试面试题总结-腾讯[实习]科恩实验室-安全工程师(题目+回答)

安全领域各种资源&#xff0c;学习文档&#xff0c;以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具&#xff0c;欢迎关注。 目录 腾讯[实习]科恩实验室-安全工程师 一、网络与协议 1. TCP三次握手 2. SYN扫描原理 3. HTTPS证书机制 二…...

【C++进阶篇】智能指针

C内存管理终极指南&#xff1a;智能指针从入门到源码剖析 一. 智能指针1.1 auto_ptr1.2 unique_ptr1.3 shared_ptr1.4 make_shared 二. 原理三. shared_ptr循环引用问题三. 线程安全问题四. 内存泄漏4.1 什么是内存泄漏4.2 危害4.3 避免内存泄漏 五. 最后 一. 智能指针 智能指…...

群晖NAS如何在虚拟机创建飞牛NAS

套件中心下载安装Virtual Machine Manager 创建虚拟机 配置虚拟机 飞牛官网下载 https://iso.liveupdate.fnnas.com/x86_64/trim/fnos-0.9.2-863.iso 群晖NAS如何在虚拟机创建飞牛NAS - 个人信息分享...

提升移动端网页调试效率:WebDebugX 与常见工具组合实践

在日常移动端开发中&#xff0c;网页调试始终是一个高频但又极具挑战的环节。尤其在面对 iOS 与 Android 的混合技术栈、各种设备差异化行为时&#xff0c;开发者迫切需要一套高效、可靠且跨平台的调试方案。过去&#xff0c;我们或多或少使用过 Chrome DevTools、Remote Debug…...