7.List类型

List相当于数组 或 顺序表;**编码方式上,类似于双端队列,**头插头删时间复杂度O(1);支持下标进行访问,头从0开始,支持负数下标;

1.列表特性

列表是有序的:[1,2,3] 和 [3,2,1] 是不同的列表,元素放置的顺序不同,列表不同;

列表元素是允许重复的;

列表的头尾插入删除时间复杂度都是O(1),因此适合实现 栈/队列 等结构;(Redis最早用作消息队列时就是通过list类型,后通过stream类型)

2.列表命令

2.1 lpush、lpushx、rpush、rpushx、lrange

lpush key element [...] 头插元素 返回值:插入后列表长度

注:key存在,且value类型不为list就报错;

lpushx key element [...] 头插元素,当key存在时才插入 返回值:插入后列表长度

rpush key element[...] 尾插元素 返回值:插入后列表长度

rpushx key element[...] 尾插元素,当key存在时才插入 返回值:插入后列表长度

lrange key start stop 取出从start到stop所有元素,时间复杂度O(N)

2.2 lpop、rpop、lindex、linsert、llen

lpop key 头删,O(1),返回值:被删除的元素

rpop key 尾删,O(1),返回值:被删除的元素

注:redis 6.2及以上版本,lpop和rpop可以带[count],表示删除几个

lindex key index 获取从左往右数下标位置的元素 返回值:元素 或 nil,时间复杂度:O(N)

linsert key <BEFORE | AFTER> pivot element 在基准值之前或之后插入元素,

返回值:插入后列表元素个数 或 -1(如果pivot不存在,不插入,返回-1)

时间复杂度:O(N)

llen key 获取列表长度

2.3 lrem、ltrim、lset

lrem key count element 删除count个值等于element元素

时间复杂度:O(N)

返回值:实际删除的element个数
count>0,从左往右删;
count<0,从右往左删;

count=0,删除全部等于element的;

ltrim key start stop 只保留[start, stop]区间内的元素

lset key index element 修改index下标位置的值,下标越界报错。O(N)

2.4 blpop、brpop

阻塞:当前线程不往后执行了,会在满足一定条件后被唤醒;

如果list不为空,直接删除后返回即可;

如果list为空,blpop和brpop就会阻塞,直到list不为空为止;

阻塞队列(生产者消费者模型)特性:

1)线程安全

2)队列满了,生产者入队列阻塞;队列空了,消费者出队列阻塞

redis的list相当于阻塞队列,线程安全是通过单线程模型来实现的;且只考虑队列为空情况;

blpop和brpop可以显式设置阻塞时间timeout,阻塞期间redis可以执行其他命令,并不会对redis执行命令线程造成负面影响;

blpop key [...] timeout 可以一次等待多个key,timeout可以为小数,单位秒

brpop key [...] timeout 可以一次等待多个key

多个客户端执行blpop,最先到达的先执行。

返回值:来自于哪个key,删除的是哪个元素;

3.列表编码方式

ziplist 和 linkedlist,过时;

quicklist,压缩列表和链表的结合,整体是一个链表,单个节点是一个压缩列表;

配置文件:/etc/redis/redis.conf 中 list-max-ziplist-xxx 过时

4.列表应用场景

4.1 作为数组存储多个元素

模拟mysql表结构:

使用key-list结构,list存储具体的属性信息。

4.2 使用redis作为消息队列

通过blpop、brpop命令来实现,只关注列表为空情况;

相关推荐
fengxin_rou21 小时前
[Redis从零到精通|第四篇]:缓存穿透、雪崩、击穿
java·redis·缓存·mybatis·idea·多线程
是阿楷啊1 天前
Java大厂面试场景:音视频场景中的Spring Boot与微服务实战
spring boot·redis·spring cloud·微服务·grafana·prometheus·java面试
笨蛋不要掉眼泪1 天前
Redis哨兵机制全解析:原理、配置与实战故障转移演示
java·数据库·redis·缓存·bootstrap
ALex_zry1 天前
Redis Cluster 分布式缓存架构设计与实践
redis·分布式·缓存
乔江seven2 天前
【Flask 进阶】3 从同步到异步:基于 Redis 任务队列解决 API 高并发与长耗时任务阻塞
redis·python·flask
这周也會开心2 天前
Redis与MySQL回写中的数据类型存储设计
数据库·redis·mysql
shuair2 天前
redis缓存预热、缓存击穿、缓存穿透、缓存雪崩
redis·spring·缓存
shuair2 天前
guava布隆过滤器及cuckoo过滤器
redis·guava
上架ipa2 天前
redis图形化客户端功能对比
redis·缓存
indexsunny2 天前
互联网大厂Java面试实战:微服务与Spring生态技术解析
java·spring boot·redis·kafka·mybatis·hibernate·microservices