list介绍

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

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


相关使用

左右或者头尾压入元素
    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


去处指定范围外元素

      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
posted on 2021-09-17 14:52  学海无涯,书山有路  阅读(204)  评论(0)    收藏  举报