「进击Redis」六、Redis List运用场景、API解析

1,184 阅读2分钟

不懂就问

灵魂拷问之 ☞光头洗头用洗面奶还是洗发水?
好哥哥们把脑洞留在评论区吧。

概述

列表(list)类型是用来存储多个有序的字符串,如下图,三个元素从左到右组成了一个有序的列表,列表中的每个字符串称为元素(element),一个列表最多可以存储 2 的 32 次方减 1 个元素。好哥哥们看这图很像什么呢,是不是类似于 JAVA 中的 LinkedList(怎么又是 JAVA)。
在 Redis 中,可以对列表两端插入(push)和弹出(pop),还可以获取指定范围的元素列表、获取指定索引下标的元素等。列表是一种比较灵活的数据结构,它可以充当栈和队列的角色,在实际开发上有很多应用场景。 list

1 命令

主要围绕下面五个操作来说,好哥哥们,看图:
命令

1.1 添加操作

 ## 从右边插入元素(right)
 rpush key value [value ...]
 ## 下面代码从右向左插入元素
 rpush city:guangdong guangzhou chaoshan shenzhen
 ## 从左边插入元素(left)
 lpush key value [value ...]
 ## 下面代码从左向右插入元素
 rpush city:guangdong shenzhen chaoshan guangzhou
 ## 向某个元素前或者后插入元素, linsert命令会从列表中找到等于(pivot)的元素,在其前(before)或者后(after)插入一个新的元素(value)
 linsert key before|after pivot value
 ## 在潮汕前插入一个元素zhongshan,返回的是列表长度
 linsert city:guangdong before chaoshan zhongshan

1.2 查找

 ## 获取指定范围内的元素列表。索引下标从左到右分别是0到N-1,但是从右到左分别是-1到-N。lrange中的end选项包含了自身,这个和很多编程语言不包含end不太相同。
 lrange key start end
 ## 返回的就是从1到包含3的列表,zhongshan chaoshan guangzhou
 lrange city:guangdong 1 3
 ## 获取列表指定索引下标的元素
 lindex key index
 ## 获取city:guangdong索引为1的元素 guangzhou
 lindex city:guangdong 1
 ## 获取列表长度
 llen key
 ## 获取city:guangdong的长度,返回4
 llen city:guangdong

1.3 删除

 ## 从列表左侧弹出元素
 lpop key
 ## 从左侧删除一个元素
 lpop city:guangdong
 ## 从列表右侧弹出
 rpop key
  ## 从右侧删除一个元素
 rpop city:guangdong
 ## 删除指定元素。从列表中找到等于value的元素进行删除。
 ## 如果count>0,从左到右,删除最多count个元素。如果count=0,删除所有。
 ## 如果count<0,从右到左,删除最多count绝对值个元素。
 lrem key count value
 ## 比如我们的列表为a a a guangzhou zhongshan chaoshan guangzhou,执行下面命令结果为guangzhou zhongshan chaoshan guangzhou
 lrem city:guangdong 3 a
 ## 按照索引范围修剪列表,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。
 ltrim key start end
 ## 下面操作会只保留列表city:guangdong第2个到第4个元素
 ltrim city:guangdong 1 3

1.4 修改

 ## 修改指定索引下标的元素
 lset key index newValue
 ## 将第一个元素修改为beijing
 lset city:guangdong 0 beijing

1.5 阻塞操作

 ## 阻塞式弹出,blpop和brpop是lpop和rpop的阻塞版本
 ## key[key...]:多个列表的键,timeout:阻塞时间(单位:秒)
 ## 注意点一、如果是多个键,那么brpop会从左至右遍历键,一旦有一个键能弹出元素,客户端立即返回
 ## 注意点二、如果多个客户端对同一个键执行brpop,那么最先执行brpop命令的客户端可以获取到弹出的值。
 blpop key [key ...] timeout
 brpop key [key ...] timeout
 ## 如果里里列表中没有元素,阻塞三秒后返回,如果设置为0,则会一直阻塞,如果此期间添加了数据element1,客户端立即返回。
 ## 列表不为空:客户端会立即返回
 brpop city:guangdong 3

2 时间复杂度

老规矩,看图不说话 复杂度

3 使用场景

  1. 消息队列,通过 lpush+brpop 命令组合即可实现阻塞队列。正常是不会这么玩的。
  2. 最新列表,List 类型的 lpush 命令和 lrange 命令能实现最新列表的功能,每次通过 lpush 命令往列表里插入新的元素,然后通过 lrange 命令读取最新的元素列表,如朋友圈的点赞列表、评论列表。
  3. 排行榜, List 类型的 lrange 命令可以分页查看队列中的数据, 但是只有定时计算的排行榜才适合使用 list 类型存储(实时不行)。

本期就到这啦,有不对的地方欢迎好哥哥们评论区留言,另外求关注、求点赞\color{#FF0000}{求关注、求点赞}

下一篇:Redis Set 运用场景、API 解析
上一篇:Redis Hash 运用场景、API 解析