不懂就问
灵魂拷问之 ☞光头洗头用洗面奶还是洗发水?
好哥哥们把脑洞留在评论区吧。
概述
列表(list)类型是用来存储多个有序的字符串,如下图,三个元素从左到右组成了一个有序的列表,列表中的每个字符串称为元素(element),一个列表最多可以存储 2 的 32 次方减 1 个元素。好哥哥们看这图很像什么呢,是不是类似于 JAVA 中的 LinkedList(怎么又是 JAVA)。
在 Redis 中,可以对列表两端插入(push)和弹出(pop),还可以获取指定范围的元素列表、获取指定索引下标的元素等。列表是一种比较灵活的数据结构,它可以充当栈和队列的角色,在实际开发上有很多应用场景。
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 使用场景
- 消息队列,通过 lpush+brpop 命令组合即可实现阻塞队列。正常是不会这么玩的。
- 最新列表,List 类型的 lpush 命令和 lrange 命令能实现最新列表的功能,每次通过 lpush 命令往列表里插入新的元素,然后通过 lrange 命令读取最新的元素列表,如朋友圈的点赞列表、评论列表。
- 排行榜, List 类型的 lrange 命令可以分页查看队列中的数据, 但是只有定时计算的排行榜才适合使用 list 类型存储(实时不行)。
本期就到这啦,有不对的地方欢迎好哥哥们评论区留言,另外