列表 是一种比较 灵活 的 数据结构,它可以充当 栈 和 队列 的角色,在实际开发上有很多应用场景。
如图所示,a
、b
、c
、d
、e
五个元素 从左到右 组成了一个 有序的列表,列表中的每个字符串称为 元素(element
),一个列表最多可以存储 2 ^ 32 - 1
个元素。
- 列表的 插入 和 弹出 操作
- 列表的 获取、截取 和 删除 操作
1. 相关命令
下面将按照对 列表 的 5
种 操作类型 对命令进行介绍:
1.1. 添加命令
1.1.1. 从右边插入元素
rpush key value [value ...]
下面代码 从右向左 插入元素 c
、b
、a
:
127.0.0.1:6379> rpush listkey c b a
(integer) 3
复制代码
lrange 0 -1
命令可以 从左到右 获取列表的 所有元素:
127.0.0.1:6379> lrange listkey 0 -1
1) "c"
2) "b"
3) "a"
复制代码
1.1.2. 从左边插入元素
lpush key value [value ...]
使用方法和 rpush
相同,只不过从 左侧插入,这里不再赘述。
1.1.3. 向某个元素前或者后插入元素
linsert key before|after pivot value
linsert
命令会从 列表 中找到 第一个 等于 pivot
的元素,在其 前(before
)或者 后(after
)插入一个新的元素 value
,例如下面操作会在列表的 元素 b
前插入 redis
:
127.0.0.1:6379> linsert listkey before b redis
(integer) 4
复制代码
返回结果为 4
,代表当前 列表 的 长度,当前列表变为:
127.0.0.1:6379> lrange listkey 0 -1
1) "c"
2) "redis"
3) "b"
4) "a"
复制代码
1.2. 查询命令
1.2.1. 获取指定范围内的元素列表
lrange key start stop
lrange
操作会获取列表 指定索引 范围所有的元素。
索引下标 有两个特点:
-
其一,索引下标 从左到右 分别是
0
到N-1
,但是 从右到左 分别是-1
到-N
。 -
其二,
lrange
中的end
选项包含了 自身