零基础学习Redis(8) -- list类型命令使用

list相当于一个顺序表。

1. list常用命令

1. lpush / rpush

lpush key value1 value2 ...

rpush key value1 value2..

lpush(left push)从左边插入元素,头插;rpush(right push)从右边插入元素,尾插

两者都会返回插入后的列表长度,并且插入一个元素的时间复杂度都是O(1)

2. lrange

lrange key start stop

lrange(list range)查询列表区间的元素,注意是闭区间,支持使用负数下标:

如果区间超出范围会返回区间内存在的元素,不存在元素返回空列表:

3. lpushx / rpushx

lpushx key value1 value2 ...

rpushx key value1 value2..

和lpush / rpush使用方法相同,不过只有列表中存在元素时才会成功

4. lpop / rpop 

lpop key [count]

rpop key [count]

lpop(left pop) 头删,rpop(right pop)尾删。 

count 代表要删除的数量,不写则默认删除一个,删除后会返回被删除的值:

5. lindex 

lindex key index 

lindex(list index)查询指定下标的元素,如果下标不存在返回nil,时间复杂度为O(N):

 

 6. linsert

linsert <before | after> pivot element

linsert(list insert)在列表中第一个值为pivot元素的前面或后面插入元素element ,返回插入后列表的长度,时间复杂度为O(N):

7. llen

llen key

llen(list length)查询列表中的元素个数:

8. lrem 

lrem key count element

lrem(list remove) 删除列表中的element,当count 等于0删除全部的element,大于0时从左往右删count个,小于0时从右往左删-count个:

9. ltrim

ltrim key start stop 

保留start 到 stop区间内的元素:

10. lset 

lset key index element 

修改index下标下的元素为element,下标存在才能执行成功

 11. blpop / brpop

blpop key1 key2 timeout

brpop key1 key2 timeout

功能和lpop / rpop类似,从一个或多个key中头删/尾删一个元素,并且带有阻塞功能,当列表中没有元素时会阻塞等待,直到超时时间或者列表中被添加了元素:

有元素会立即返回,key和对应的数据,超过设置时间则返回nil:

 

使用blpop和brpop不会阻塞redis线程。

2. 内部编码

前面我们介绍时说的的使用 ziplist 和 linkedList,实际上5.多版本使用的是quicklist,quicklist,本质上还是一个链表,但是每个节点都是一个ziplist,节点的大小可以通过修改redis.conf文件来调整,当某个点大小超过设置大小就会分裂为两个节点:

可以看到默认是 -2 ,通过上面注释可以直到每个节点超过8kb就会分裂 

3. 应用场景

1. 用作数组,存储一些同类的数据,例如一个班级的学生

2. 用作阻塞队列,使用brpop/blpop/lpush/rpush可以很简单的模拟一个生产者消费者模型

3. 用于分页查询,使用lrange命名可以指定查询的范围区间

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ting-yu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值