list的介绍和使用

list介绍

基于Linked List实现
元素是字符串类型
列表头尾增删快,中间增删慢,增删元素是常态
元素可以重复出现
最多包含2^32-1元素

list的介绍和使用

列表的索引
    从左至右,从0开始
    从右至左,从-1开始

list的介绍和使用
相关使用
左右或者头尾压入元素
LPUSH key value [value ...]
LPUSHX key value
RPUSH key value [value ...]
RPUSHX key value

左右或者头尾弹出元素
    LPOP key
    RPOP key
    从一个列表尾部弹出元素压入到另一个列表的头部
    RPOPLPUSH source destination
    返回列表中指定范围元素
    LRANGE key start stop
    LRANGE key 0 -1 表示返回所有元素
  获取指定位置的元素
  LINDEX key index
  设置指定位置元素的值
  LSET key index value
  列表长度,元素个数
  LLEN key
从列表头部开始删除值等于value的元素count次
  LREM key count value
  count > 0 : 从表头开始向表尾搜索,移除与 value 相等的元素,数量为 count
  count < 0 : 从表尾开始向表头搜索,移除与 value 相等的元素,数量为 count 的绝对值
  count = 0 : 移除表中所有与 value 相等的值
  举例
  RPUSH listkey c abc c ab 123 ab bj ab redis list
  LREM listkey 2 ab
  LRANGE listkey 0 -1

list的介绍和使用

去处指定范围外元素

LTRIM key start stop
举例
RPUSH listkey c abc c ab 123 ab bj ab redis list
LTRIM listkey 0 -1
LTRIM listkey 1 -1
LTRIM listkey 1 10000
微博的评论最后500条
LTRIM u1234:forumid:comments 0 499

在列表中某个存在的值(pivot)前或后插入元素

LINSERT key BEFORE|AFTER pivot value
key和pivot不存在,不进行任何操作
举例
RPUSH lst Clojure C Lua
LINSERT lst AFTER  C Python
LINSERT lst BEFORE C Ruby

阻塞

如果弹出的列表不存在或者为空,就会阻塞
超时时间设置为0,就是永久阻塞,直到有数据可以弹出
如果多个客户端阻塞在同一个列表上,使用First In First Service原则,先到先服务
左右或者头尾阻塞弹出元素
BLPOP key [key ...] timeout
BRPOP key [key ...] timeout
从一个列表尾部阻塞弹出元素压入到另一个列表的头部
BRPOPLPUSH source destination timeout
上一篇:在 《数学问题,连接两个点的曲线旋转所成曲面中,面积最小的曲线是什么?》 里 的 讨论


下一篇:Schwarz inequality(施瓦茨不等式)一个简洁证明的思路分析