zoukankan      html  css  js  c++  java
  • redis 学习(5)-- 列表类型

    redis 学习(5)-- 列表类型

    列表特点

    • 有序、可以重复、左右两边插入弹出
    • 索引相关知识
      • 索引从左往右,从0开始逐个增大 0 1 2 3 4 5
      • 索引从右往左,从-1开始逐个减小 -6 -5 -4 -3 -2 -1

    重要 API

    命令 含义
    rpush key value1 [value2...] 在列表后侧添加一个或多个值
    lpush key value1 [value2...] 在列表左侧添加一个或多个值
    linsert key before/after value newValue 在列表指定的value前/后插入newValue,时间复杂度为O(n)
    lpop key 从列表左侧弹出一个值
    rpop key 从列表右侧弹出一个值
    lrem key count value 根据count值,从列表中删除值为value的项,时间复杂度为O(n)。count > 0 时,从左往右遍历,删除最多count个与value相等的值;count < 0 时,从右往左遍历,删除最多Math.abs(count)个与value相等的值;count = 0 时,删除所有与value相等的值
    trim key start end 对一个列表进行修剪,只保留指定区间内的元素,不在区间内的元素都将被删除,时间复杂度为O(n)
    lrange key start end 获取列表指定索引范围的所有元素,时间复杂度为O(n)
    lindex key index 获取列表指定索引的元素,时间复杂度为O(n)
    llen key 获取列表长度,时间复杂度为O(1)
    lset key index newValue 设置列表指定索引的值为newValue,时间复杂度为O(n)。必须存在这个值才能设置成功,否则会报错
    blpop key timeout 移除并获取列表左边第一个元素,如果列表没有元素会阻塞直到等待超时或可弹出元素为止。timeout单位为秒,timeout=0时不阻塞
    brpop key timeout 移除并获取列表右边第一个元素,如果列表没有元素会阻塞直到等待超时或可弹出元素为止。timeout单位为秒,timeout=0时不阻塞

    演示

    实战

    时间轴功能(TimeLine)

    使用 lpush 更新,rpop、lpop 删除,lrange 做排序分页等。类似微博的发布信息流。

    一些小建议

    当我们想实现一些功能的时候,可以结果各种命令组合使用。

    1. LRUSH + LPOP = Stack (实现栈)
    2. LPUSH + RPOP = Queue (实现队列)
    3. LPUSH + LTRIM = Capped Collection (实现有固定数量的列表)
    4. LPUSH + BRPOP = Message Queue (实现消息队列)
  • 相关阅读:
    mysql备份还原
    matlab学习笔记一
    tic和toc用来记录matlab命令执行的时间
    Flume的JVM优化策略
    Linux中的grep -R命令详解
    Hadoop集群Unhealthy Nodes导致计算能力下降解决方法 (nodemanager处于Unhealthy Nodes)
    Java匿名内部类详解
    Error:java: Compilation failed: internal java compiler error 解决办法
    java基础知识体系
    使用flink SQL对接kafka 时,日志不报错,也没有数据输出,原因有哪几个方面
  • 原文地址:https://www.cnblogs.com/weixuqin/p/10937695.html
Copyright © 2011-2022 走看看