文章目录
1. List介绍
List(列表)类型用于存储一系列有序的字符串元素。每个列表项都是一个字符串,列表本身是按照插入顺序排序的,这意味着你可以保留元素的插入顺序.
- 双向链表:Redis内部使用双向链表实现List,这使得在列表的头部或尾部插入和弹出元素都非常高效,时间复杂度为O(1)。
- 有序性:列表中的元素保持插入时的顺序,可以按照索引位置访问元素。
- 元素重复:列表允许存储重复的元素。
- 长度限制:理论上,一个列表可以包含最多2^32 - 1个元素(大约4294967295个)。
- 多种操作:支持多种操作,包括从两端添加/删除元素(LPUSH/RPUSH, LPOP/RPOP),获取指定范围内的元素(LRANGE),以及阻塞式弹出(BLPOP/BRPOP)等。
本文主要讲List类型的常用命令
2. lpush,rpush和lrange
lpush命令 将一个或多个值value插入到列表key的表头。如果key不存在,会在插入值之前创建一个空列表。当多个值被插入时,它们会按照从左到右的顺序入栈。
LPUSH key value [value ...]
rpush与rpush相似,但它是将一个或多个值value插入到列表key的表尾(右侧)。同样,如果key不存在,则先创建空列表。
RPUSH key value [value ...]
lrange返回列表key中指定范围的元素。start和stop是基于0的索引,其中0表示列表的第一个元素,-1表示最后一个元素。如果stop被省略或设置为-1,则返回从start到列表结束的所有元素。
LRANGE key start stop
示例:
127.0.0.1:6379> lpush list1 1 2 3 4 5 # 注意遍历时的顺序
(integer) 5
127.0.0.1:6379> lrange list1 0 -1
1) "5"
2) "4"
3) "3"
4) "2"
5) "1"
127.0.0.1:6379> rpush list2 1 2 3 4 5# 注意遍历时的顺序
(integer) 5
127.0.0.1:6379> lrange list2 0 -1
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
127.0.0.1:637