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

Redis:list类型

Redis:list类型

    • list命令
      • 非阻塞
        • LPUSH
        • LRANGE
        • LPUSHX
        • RPUSH
        • RPUSHX
        • LPOP
        • RPOP
        • LINDEX
        • LINSERT
        • LLEN
        • LREM
        • LTRIM
        • LSET
      • 阻塞
        • BLPOP
        • BRPOP
    • 内部编码
      • ziplist
      • linkedlist
      • quicklist


几乎每种语言都有顺序表数组链表这样的顺序结构,Redis也做出了相应的支持。

在这里插入图片描述

如图,Redisvalue值可以是一个列表list,其支持头尾的插入删除,下标访问等功能。也支持正负数下标,正数下标从0开始,负数下标从-1开始。


list命令

非阻塞

LPUSH
  • 头插元素到list中,如果key不存在就创建
lpush key element [element ...]

返回list插入后的长度。如果一开始key不存在,就创建一个key


LRANGE
  • 获取指定范围的list元素
lrange key start stop

访问区间为[start, end]的闭区间,支持负数下标。

示例:

接下来通过lrange测试刚刚的lpush接口:

在这里插入图片描述

由于lpush是头部插入,所以按顺序插入1 2 3 4 5,最后存储顺序为5 4 3 2 1

如果在Redis中数组越界,Redis不会报错,而是尽可能输出范围内存在的数据。

在这里插入图片描述

第一次查询0 - 100,但是list中只有0 - 4,那么此时把0 - 4全部输出。第二次查询50 -60list内没用这部分数据,但是它不报错,而是输出empty表示空。


LPUSHX
  • key存在,头插元素到list
lpushx key element [element ...]

返回插入后,list中元素的个数。

示例:

在这里插入图片描述

第一次插入list1,由于已经存在,此时插入成功,返回9表示当前有九个元素。第二次插入了一个不存在的list2,但是它不存在,返回0表示插入后一个元素也没有,也就是插入失败。


RPUSH
  • 尾插元素到list中,如果key不存在就创建
rpush key element [element ...]

返回插入后list元素个数。

示例:

在这里插入图片描述

同样插入1 2 3 4 5,顺序与之前lpush插入刚好是反着的,因为rpush是尾插。

此处list有一个命名上的注意点:

  • lpushleft push,从左侧插入,即头插
  • rpushright push,从右侧插入,即尾插
  • lrangelist range,输出列表指定范围

同样是l开头,有时候表示list,有时候表示left,这个要注意。

另外的:

  • lpushxleft push exists,存在时插入

此处的x是选用了exsis中的一个字母,表示只有key存在才插入。


RPUSHX
  • key存在,尾插元素到list
rpushx key element [element ...]

返回插入后,list中元素的个数。


LPOP
  • 头删list元素
lpop key [count]

返回被删除的头部count个元素,如果list为空,没有可以删的元素了,返回nil

示例:

在这里插入图片描述

先创建一个1 2 3 4 5的列表,第一次lpop不带任何参数,只输出一个头部元素。第二次带参数4,此时输出剩余的四个元素。最后一次lpop,由于已经没有元素了,返回nil


RPOP
  • 尾删list元素
rpop key [count]

返回被删除的尾部count个元素,如果list为空,没有可以删的元素了,返回nil


LINDEX
  • 获取指定下标的元素
lindex key index

返回指定下标的元素,支持负数下标。

示例:

在这里插入图片描述


LINSERT
  • 在指定位置插入元素
linsert key before|after pivot element

在元素pivot的前面或者后面插入element元素。

示例:

在这里插入图片描述

此处指令的作用是,在元素c前面插入hello

如果有多个pivot元素,那么只在第一个元素的位置插入。


LLEN
  • 获取list的长度
llen key

返回list长度,如果不存在则返回0


LREM
  • 删除元素
lrem key count element

删除countelement元素。

此处count的取值有三种:

  • count > 0:从左往右删除
  • count < 0:从右往左删除
  • count = 0:删除所有元素

示例:

在这里插入图片描述

此处插入了1 2 3 hello循环四次,删除3 hello,即从左往右删除三个hello每次出只有最后一个hello被保留。

在这里插入图片描述

如果传入-3 hello,此时从右往左删除,只有第一个hello被保留。


LTRIM
  • 指定范围内元素保留,剩余的元素删除
ltrim key start stop

只保留[start, stop]闭区间内部的元素,其余的元素全部删除。

示例:

在这里插入图片描述


LSET
  • 修改指定下标的元素
lset key index element

将下标为index的元素改为element,支持负数下标。如果下标越界,会返回一个报错。

示例:

在这里插入图片描述

第一次修改,将下标为3的元素修改为666。第二次插入,操作下标为100的元素,由于不存在,报错了。


阻塞

先前的所有的命令,都是非阻塞的,直接操作就可以得到结果,而list还提供了一些阻塞性质的命令。

在多线程中,有一个生产消费模型,其可以基于阻塞队列实现,主要满足以下两个性质:

  1. 如果阻塞队列满了,那么生产者阻塞
  2. 如果阻塞队列空了,那么消费者阻塞

Redis中,list只考虑队列为空的情况,也就是消费者。用户读取数据时,队列为空,那么用户陷入阻塞,直到队列有数据

BLPOP
  • 读取并删除list头部元素,如果没有元素则陷入阻塞
blpop key [key ...] timeout

blpop可以同时指定多个key,也就是多个list,只要任何一个list有数据,就返回结果。还可以设置超时时间timeout,以秒为单位,如果超过时间了,返回nil

如果超时时间设置为0,则一直阻塞,不会超时。

另外的,此处的阻塞不是Redis阻塞,而是客户端阻塞。如果阻塞,Redis将指令放到后台去等待,自己去执行其他指令。

示例:

在这里插入图片描述

此处list8有元素,而list9为空,返回了list8的元素。此时会同时返回两个内容,list8表示该数据是从哪一个列表中拿到的,3则是拿到的数据。

在这里插入图片描述

此处启用了两个客户端,左侧客户端blpop一个空列表,等待20s,随后陷入阻塞。接着右侧客户端插入一个元素到list9,随后左侧客户端立刻拿到数据并输出,并且输出了自己的阻塞市场18.15s


BRPOP
  • 读取并删除list尾部元素,如果没有元素则陷入阻塞
brpop key [key ...] timeout

总结:

操作类型命令
添加rpushlpushinsert
查找lrangelindexllen
删除lpoprpoplremltrim
修改lset
阻塞blpopbrpop

内部编码

ziplist

压缩列表是一种内存紧凑的存储方式,适合存储数量较少且元素较小的列表。具体来说,当list类型的元素个数小于 list-max-ziplist-entries (默认 512 个),并且所有值的长度都小于 list-max-ziplist-value (默认 64 字节)时,Redis 会使用 ziplist 作为列表的内部实现。

这些配置在/etc/redis/redis.conf内修改。

优点:

  1. 内存节省ziplist 使用连续的内存块来存储数据,这种紧凑的存储方式可以有效地减少内存碎片和开销。
  2. 结构简单:适合小规模数据,尤其是在内存资源有限的情况下。

缺点:

  1. 操作效率:随着数据量的增加,ziplist 的读写效率会下降。尤其是在需要频繁更新的场景中,ziplist 的线性查找特性使得操作复杂度较高。
  2. 扩展性差:不适合大规模数据存储。

linkedlist

当列表类型无法满足ziplist的条件时,会使用linkedlist链表作为list的内部实现。这就是一个基本的双向链表。

优点:

  1. 头尾的插入删除非常高效

缺点:

  1. 中间部分的插入删除时间复杂度较高

quicklist

linkedlistziplist 编码在 Redis 4.0 版本之后不再是默认的列表编码方式,因为引入了更高效的 quicklist 编码,它是基于压缩列表和双向链表的组合,旨在结合两者的优点。

对于quicklist,其外层列表依然是linkedlist双链表结构,但是每一个链表节点都是一个quicklist,对于中间部分的节点,会进行一定程度的压缩,提高效率。


相关文章:

Redis:list类型

Redis&#xff1a;list类型 list命令非阻塞LPUSHLRANGELPUSHXRPUSHRPUSHXLPOPRPOPLINDEXLINSERTLLENLREMLTRIMLSET 阻塞BLPOPBRPOP 内部编码ziplistlinkedlistquicklist 几乎每种语言都有顺序表、数组、链表这样的顺序结构&#xff0c;Redis也做出了相应的支持。 如图&#xff…...

政府采购方式有哪些,竞争性谈判和竞争性磋商的区别

政府采购的方式主要包括公开招标、邀请招标、竞争性谈判、竞争性磋商、询价、单一来源采购和框架协议采购等几种。以下是对这些方式的具体介绍&#xff1a; 公开招标 定义&#xff1a;公开招标是指采购单位依法以招标公告的方式邀请不特定的供应商参与投标的采购方式。适用情形…...

【JavaScript】移动色块案例 实现一个可以拖动并且在拖动过程中会自动改变颜色的色块(JS 事件监听器)

移动色块案例 实现一个可以拖动并且在拖动过程中会自动改变颜色的色块。 移动色块&#xff1a;用户可以通过鼠标按住并拖动页面上的红色方块&#xff08;#blocks&#xff09;。当用户按下鼠标左键时&#xff0c;色块开始跟随鼠标的移动而移动&#xff1b;当用户释放鼠标左键时…...

[Linux#62][TCP] 首位长度:封装与分用 | 序号:可靠性原理 | 滑动窗口:流量控制

目录 一. 认识TCP协议的报头 1.TCP头部格式 2. TCP协议的特点 二. TCP如何封装与分用 TCP 报文封装与解包 如何封装解包&#xff0c;如何分用 分离有效载荷 隐含问题&#xff1a;TCP 与 UDP 报头的区别 封装和解包的逆向过程 如何分用 TCP 报文 如何通过端口号找到绑…...

【中短文】区分神经网络中 表征特征、潜层特征、低秩 概念

1. 表征特征&#xff08;Representational Feature&#xff09;&#xff1a; 表征特征通常指的是输入数据经过NN处理就得到的中间表示或输出表示。 这些特征由NN经学习过程自动提取&#xff0c;能更好捕捉输入数据的本质属性。 例如&#xff1a;在图像识别任务中&…...

MySQL8.0环境部署+Navicat17激活教程

安装MySQL 下载MySQL MySQL官网下载当前最新版本&#xff0c;当前是8.0.39。 选择No thanks, just start my download等待下载即可。 安装MySQL 下载完成后&#xff0c;双击安装进入安装引导页面。选择Custom自定义安装。 选择MySQL Server 8.0.39 - X64安装。 点击Execute执…...

每日读则推(十)——Elon Musk‘s speech on self-driving at Tesla‘s annual meeting

Elon Musk: You cant solve self-driving unless you have millions of cars on the road. n.自动驾驶 v.限制,约束,强迫,迫使“We are no longer compute-constrained for training. 不再 n/v.估算,计…...

C++新特性——外部模板

1、What C++11标准引入的一种机制,允许在头文件中声明模板,但仅在一个单独的源文件中显式实例化这些模板。这一机制使得编译器只需要在源文件中实例化模板一次,其它源文件引用已经实例化的模板,从而减少编译时间和生成的二进制文件大小。 2、Why 2.1 优化编译时间 模板实…...

字节跳动青训营开始报名了!

关于青训营&#xff1a; 青训营是字节跳动技术团队发起的技术系列培训 &人才选拔项目;面向高校在校生&#xff0c;旨在培养优秀且具有职业竞争力的开发工程师。 本次技术训练营由掘金联合豆包MarsCode 团队主办课程包含前端、后端和 A 方向&#xff0c;在这个飞速发…...

从SQL Server过渡到PostgreSQL:理解模式的差异

前言 随着越来越多的企业转向开源技术&#xff0c;商业数据库管理员和开发者也逐渐面临向PostgreSQL迁移的需求。 虽然SQL Server和PostgreSQL共享许多数据库管理系统&#xff08;RDBMS&#xff09;的基本概念&#xff0c;但它们在处理某些结构上的差异可能会让人感到困惑&…...

刷题 排序算法

912. 排序数组 注意这道题目所有 O(n^2) 复杂度的算法都会超过时间限制&#xff0c;只有 O(nlogn) 的可以通过 快速排序空间复杂度为 O(logn)是由于递归的栈的调用归并排序空间复杂度为 O(n) 是由于需要一个临时数组 (当然也需要栈的调用&#xff0c;但是 O(logn) < O(n) 的…...

【python3】tornado高性能编程

使用多进程充分利用cpu使用异步编程 asyncio import asyncio import time from abc import ABC from concurrent.futures import ProcessPoolExecutor from tornado import web, ioloop, genasync def async_task(name):print(f"start: {name}")st int(time.time()…...

构建高效购物推荐系统:SpringBoot实战

1系统概述 1.1 研究背景 如今互联网高速发展&#xff0c;网络遍布全球&#xff0c;通过互联网发布的消息能快而方便的传播到世界每个角落&#xff0c;并且互联网上能传播的信息也很广&#xff0c;比如文字、图片、声音、视频等。从而&#xff0c;这种种好处使得互联网成了信息传…...

docker tar包安装 docker-26.1.4.tgz

一、docker安装 1.先将docker安装包&#xff08;docker-26.1.4.tgz&#xff09;拷贝到DM系统中。 下载地址 Index of linux/static/stable/x86_64/ 1.先将docker安装包&#xff08;docker-26.1.4.tgz&#xff09;拷贝到DM系统中。 2.解压docker安装包 tar zxf docker-26.1.…...

Github 2024-10-12 Rust开源项目日报 Top10

根据Github Trendings的统计,今日(2024-10-12统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Rust项目10JavaScript项目1Svelte项目1TypeScript项目1Rust: 构建可靠高效软件的开源项目 创建周期:5064 天开发语言:Rust协议类型:OtherSta…...

Spring Cloud 微服务架构及其应用:设计、实现与优化

引言 随着互联网技术的不断发展,传统的单体应用架构逐渐暴露出了一些问题,如扩展性差、维护复杂、部署不灵活等。为了解决这些问题,微服务架构应运而生。微服务是一种将应用程序分解为一组小的、自治的服务的架构模式,服务之间通过轻量级的通信协议(如HTTP)进行交互。Sp…...

Rider + xmake DX12 开发环境

Rider xmake DX12 开发环境 背景 如题&#xff0c;想要接近 UE 的开发流程 正文 大的流程就是 xmake 生成 vs 的 sln&#xff0c;用 Rider 进行开发 intellisense&#xff0c;断点调试 加了个脚本手动刷新 sln xmake project -k vsxmake -m "debug;release" -…...

控制台java原生工具打包jar文件

1、进入java源代码所在路径&#xff0c;或者包起始文件的所在路径 2、编译为class文件 我没配全局变量&#xff0c;这里使用jdk的完整路径来调用 3、jar命令进行打包 -cfe后面: svnHook.jar 指定jar包文件名 Request 包名入口类名&#xff0c;如果有包含包的话&#xff0c;应…...

MySQL主从同步

MySQL主从同步 作用 减少单台服务器的压力&#xff0c;防止单点故障 部署 主库 编辑/etc/mysql/mysql.conf.d/mysqld.cnf log_binmysql-bin server-id1 #服务器的id,再主从数据库里不能重复重启MySQL服务器 systemctl restart mysql连接mysql&#xff0c;并创建用于主从…...

ansible 学习之变量

参考文档&#xff1a; http://www.ansible.com.cn/docs/playbooks_variables.html#variables 合法的变量 ansible变量是有数字&#xff0c;字母&#xff0c;下划线组成并且变量始终应该以字母开头。 “foo_port”是个合法的变量名.”foo5”也是. “foo-port”, “foo port”, …...

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…...

1.3 VSCode安装与环境配置

进入网址Visual Studio Code - Code Editing. Redefined下载.deb文件&#xff0c;然后打开终端&#xff0c;进入下载文件夹&#xff0c;键入命令 sudo dpkg -i code_1.100.3-1748872405_amd64.deb 在终端键入命令code即启动vscode 需要安装插件列表 1.Chinese简化 2.ros …...

【项目实战】通过多模态+LangGraph实现PPT生成助手

PPT自动生成系统 基于LangGraph的PPT自动生成系统&#xff0c;可以将Markdown文档自动转换为PPT演示文稿。 功能特点 Markdown解析&#xff1a;自动解析Markdown文档结构PPT模板分析&#xff1a;分析PPT模板的布局和风格智能布局决策&#xff1a;匹配内容与合适的PPT布局自动…...

拉力测试cuda pytorch 把 4070显卡拉满

import torch import timedef stress_test_gpu(matrix_size16384, duration300):"""对GPU进行压力测试&#xff0c;通过持续的矩阵乘法来最大化GPU利用率参数:matrix_size: 矩阵维度大小&#xff0c;增大可提高计算复杂度duration: 测试持续时间&#xff08;秒&…...

【python异步多线程】异步多线程爬虫代码示例

claude生成的python多线程、异步代码示例&#xff0c;模拟20个网页的爬取&#xff0c;每个网页假设要0.5-2秒完成。 代码 Python多线程爬虫教程 核心概念 多线程&#xff1a;允许程序同时执行多个任务&#xff0c;提高IO密集型任务&#xff08;如网络请求&#xff09;的效率…...

大语言模型(LLM)中的KV缓存压缩与动态稀疏注意力机制设计

随着大语言模型&#xff08;LLM&#xff09;参数规模的增长&#xff0c;推理阶段的内存占用和计算复杂度成为核心挑战。传统注意力机制的计算复杂度随序列长度呈二次方增长&#xff0c;而KV缓存的内存消耗可能高达数十GB&#xff08;例如Llama2-7B处理100K token时需50GB内存&a…...

push [特殊字符] present

push &#x1f19a; present 前言present和dismiss特点代码演示 push和pop特点代码演示 前言 在 iOS 开发中&#xff0c;push 和 present 是两种不同的视图控制器切换方式&#xff0c;它们有着显著的区别。 present和dismiss 特点 在当前控制器上方新建视图层级需要手动调用…...

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

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

Java后端检查空条件查询

通过抛出运行异常&#xff1a;throw new RuntimeException("请输入查询条件&#xff01;");BranchWarehouseServiceImpl.java // 查询试剂交易&#xff08;入库/出库&#xff09;记录Overridepublic List<BranchWarehouseTransactions> queryForReagent(Branch…...

算法—栈系列

一&#xff1a;删除字符串中的所有相邻重复项 class Solution { public:string removeDuplicates(string s) {stack<char> st;for(int i 0; i < s.size(); i){char target s[i];if(!st.empty() && target st.top())st.pop();elsest.push(s[i]);}string ret…...