元素是字符串类型
基于Linked List实现,元素是字符串类型
列表头尾增删快,中间增删慢,增删元素是常态,元素可以重复出现
LPUSH key value [value ...] 从左边插入一个或多个值到列表中 如果这个列表不存在就创建一个列表
>> lpush list1 0 1 2
>> lrange list1 ==> 2 1 0
LPUSHX key value 插入列表当且仅当这个列表存在时,否则返回0
RPUSH key value [value ...]
RPUSHX key value
LPOP key 从左边弹出一个元素 如果这个列表没有元素返回nil
RPOP key
返回列表中指定范围元素这个是查看即返回范围内的元素后这些元素还在原来的列表中,相当于查看
LRANGE key start stop
LRANGE key 0 -1 表示返回所有元素
RPOPLPUSH source destination 从source的右边弹出(rpop)一个元素塞进destination的左边(lpush)
>> lpush list0 0 1 2
>> lpush list1 x
>> rpoplpush list0 list1
>> lrange list0 0 -1 => 2 1
>> lrange list1 0 -1 => 0 x
LINDEX key index 获取指定下标为位置的元素(同样为查看,返回元素后这个元素依旧在原来的列表里面)
>> list1 [0,x]
>> lindex list1 1 =>x
LSET key index value 设置指定位置元素的值
>> lpush list1 0 1 2 3 4 5 =>[5 4 3 2 1 0]
>> lset list1 3 trhee =>[5 4 3 trhee 1 0] 下标从左边开始,其实也很好理解,lset嘛!
LLEN key 列表长度,元素个数
从列表头部开始删除值等于value的元素count次,LIST可以重复出现
LREM key count value
count > 0 : 从表头开始向表尾搜索,移除与 value 相等的元素,数量为 count
count < 0 : 从表尾开始向表头搜索,移除与 value 相等的元素,数量为 count 的绝对值
count = 0 : 移除表中所有与 value 相等的值
去除指定范围 外 元素
LTRIM key start stop start 和 end不被清除
>> lpush list1 0 1 2 3 4 5 6 7 8 9 ==>[9 8 7 6 5 4 3 2 1 0]
>> ltrim list1 1 7 ==> [8 7 6 5 4 3 2]
LINSERT key BEFORE|AFTER pivot value
在第一次出现的某个值的前/后插入一个值
>> rpush listx 0 1 2 3 4 5 [0 1 2 3 4 5]
>> rpush listx 0 1 2 3 4 5 [0 1 2 3 4 5 0 1 2 3 4 5]
>> linsert listx 0 X ==> [0 X 1 2 3 4 5 0 1 2 3 4 5]
阻塞操作
如果多个客户端阻塞在一个列表上则按照FIFO的模式服务
BLPOP key [key ...] timeout
BRPOP key [key ...] timeout