redis列表list类型详解

列表类型简介

列表(list)用于存储多个有序的字符串。列表是一种比较灵活的数据结构,可以充当栈和队列的角色,在实际开发上有很多应用场景

列表的特点:

  1. 列表中的元素是有序的,可以通过索引下标来获取某个元素或者某个范围内的元素列表
  2. 列表中的元素是可以重复的

命令

添加操作

rpush key value [value ...] 从右边插入元素

127.0.0.1:6379> rpush testlist a b c
(integer) 3
127.0.0.1:6379> lrange testlist 0 -1
1) "a"
2) "b"
3) "c"

lpush key value [value ...] 从左边插入元素

linsert key before|after pivot value 向某个元素前或后插入元素

从列表中找到等于pivot的元素,在其前|后插入value

127.0.0.1:6379> linsert testlist before b python
(integer) 4
127.0.0.1:6379> lrange testlist 0 -1
1) "a"
2) "python"
3) "b"
4) "c"

查找

lrange key start end 获取指定范围内的元素列表 lrange会获取列表指定索引范围所有的元素 索引下标有两个特点:

  1. 索引下标从左到右分别是0到N-1,从右到左分别是-1到-N
  2. lrange中的end选项包含了自身

获取列表第2到第4个元素:

127.0.0.1:6379> lrange testlist 1 3
1) "python"
2) "b"
3) "c"

lindex key index 获取列表指定索引下标的元素

127.0.0.1:6379> lindex testlist 1
"python"

llen key 获取列表长度 (integer) 4

删除

lpop key 从列表左侧弹出元素

127.0.0.1:6379> lpop testlist
"a"

rpop key 从列表右侧弹出元素

lrem key count value 删除指定元素 lrem从从列表中找到等于value的元素进行删除,根据count的不同分为三种情况:

  1. count>0 从左到右,删除最多count个元素
  2. count<0 从右到左,删除最多count绝对值个元素
  3. count=0 删除所有
127.0.0.1:6379> lpush testlist a a a a
(integer) 7
127.0.0.1:6379> lrange testlist 0 -1
1) "a"
2) "a"
3) "a"
4) "a"
5) "python"
6) "b"
7) "c"
127.0.0.1:6379> lrem testlist 4 a
(integer) 4
127.0.0.1:6379> lrange testlist 0 -1
1) "python"
2) "b"
3) "c"

ltrim key start end 按照索引范围修剪列表

127.0.0.1:6379> del testlist
(integer) 1
127.0.0.1:6379> lpush testlist a b c d e f g
(integer) 7
127.0.0.1:6379> ltrim testlist 1 3
OK
127.0.0.1:6379> lrange testlist 0 -1
1) "f"
2) "e"
3) "d"

修改

lset key index newValue 修改指定索引下标的元素

127.0.0.1:6379> lindex testlist 2
"d"
127.0.0.1:6379> lset testlist 2 python
OK
127.0.0.1:6379> lindex testlist 2
"python"

阻塞操作

blpop key [key ...] timeout brpop key [key ...] timeout

timeout参数:阻塞时间(秒)

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

  1. 列表为空,如果timeout=3,那么客户端要等到3秒后返回,如果timeout=0, 那么客户端一直阻塞等下去:
127.0.0.1:6379> brpop list:test 3
(nil)
(3.07s)
127.0.0.1:6379> brpop list:test 0
... 

因为列表为空,brpop会一直阻塞着等待元素的进入

此时新开一个redis-cli,新增元素入列表

127.0.0.1:6379> lpush list:test 1
(integer) 1

brpop立即返回元素:

127.0.0.1:6379> brpop list:test 0
1) "list:test"
2) "1"
(59.07s)
  1. 列表不为空,客户端立即返回结果
127.0.0.1:6379> lpush list:test 2
(integer) 1
127.0.0.1:6379> brpop list:test 1
1) "list:test"
2) "2"

注意:

  1. 如果有多个键,那么brpop会从左到右遍历键,一旦有一个键能弹出元素,客户端会立即返回
  2. 如果多个客户端对同一个键执行brpop,那么最先执行brpop命令的客户端可以获取到弹出的值

时间复杂度

列表的时间复杂度

应用场景

消息队列

redis的lpush+brpop命令组合即可实现阻塞队列,生产者客户端使用lrpush从列表左侧插入元素,多个消费者客户端使用brpop命令阻塞式的抢列表尾部的元素,多个客户端保证了消费的负载均衡和高可用性

列表的使用场景很多,以下是命令组合口诀: lpush + lpop = stack(栈) lpush + rpop = queue(队列) lpush + ltrim = capped collection(有限集合) lpush + brpop = message queue(消息队列)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Jimoer

jvm学习记录-对象的创建、对象的内存布局、对象的访问定位

简述 今天继续写《深入理解java虚拟机》的对象创建的理解。这次和上次隔的时间有些长,是因为有些东西确实不好理解,就查阅各种资料,然后弄明白了才来做记录。 (此...

2647
来自专栏章鱼的慢慢技术路

Go语言相关练习_选择题(2)

go语言中字符串是UTF-8编码并存储的,它语言不定长的字节,所以它不支持下标操作,因为没一个下标操作代表的是固定长度的字节,所以不能对字符串中某个字符单独赋值...

732
来自专栏xingoo, 一个梦想做发明家的程序员

Java直接(堆外)内存使用详解

本篇主要讲解如何使用直接内存(堆外内存),并按照下面的步骤进行说明: 相关背景-->读写操作-->关键属性-->读写实践-->扩展-->参考说明 希望对想使用直...

1989
来自专栏白驹过隙

Python - 学习经验分享

28712
来自专栏nnngu

01 深入理解JVM的内存区域

先来看看JVM运行时候的内存区域,如下图: ?   大多数 JVM 将内存区域划分为 Heap(堆)、方法区、Stack(栈)、本地方法栈、程序计数器。其中 H...

2635
来自专栏用户2442861的专栏

Java反射探索-----从类加载说起

林炳文Evankaka原创作品。转载请注明出处http://blog.csdn.net/evankaka

391
来自专栏Golang语言社区

Go语言语法汇总

最近看了看GoLang,把Go语言的语法总结了一下,做个快速参考 数据类型 ---- var varName type,var var1,var2… type,...

33413
来自专栏你不就像风一样

Java虚拟机性能监测工具Visual VM与OQL对象查询语言

Visual VM是一个功能强大的多合一故障诊断和性能监控的可视化工具,它集成了多种性能统计工具的功能,使用 Visual VM 可以代替jstat、jmap、...

793
来自专栏欧阳大哥的轮子

深入解构objc_msgSend函数的实现

熟悉OC语言的Runtime(运行时)机制以及对象方法调用机制的开发者都知道,所有OC方法调用在编译时都会转化为对C函数objc_msgSend的调用。

612
来自专栏林德熙的博客

C# const 和 readonly 有什么区别

在写常量的时候,是选择使用 const 还是 static readonly 是一个让人难以决定的问题,本文告诉大家这两个方法的区别。

552

扫码关注云+社区