1. list采用双向链表实现,获取两端元素速度快,获取中间元素速度慢,并且通过索引访问元素慢
2. 命令:
2.1 向两端增加元素:lpush key value ; rpush key value(支持添加多个元素)
2.2 从列表两端弹出元素:lpop key ; rpop key
2.3 使用:列表做栈,使用lpush和lpop或rpush和rpop
列表做队列,使用lpush和rpop或rpush和lpop
2.4 获取列表中元素个数:llen key
2.5 获得列表片段:lrange key start stop(根据索引返回元素)
2.6 删除列表中指定的值:lrem key count value(删除前count为value的元素)
当count>0时,从列表左边开始
当count<0时,从列表右边开始
当count=0,删除所有值为value的元素
2.7 获得指定索引的元素值:lindex key index
2.8 lset member index newValue (为index的元素赋新值)
2.9 ltrim key start end(删除指定索引范围之外的所有元素)
应用场景:记录日志:1、添加日志:lpush logs newlog;2、保留最近的100条:ltrim logs 0 99
3.0 向列表中插入元素:linsert key before/after member value(先找到member,然后根据before/after将value插到某个位置)
3.1 将元素从一个列表转到另一个列表:RPOPLPUSH source destination (从source右边弹出一个元素,然后加到destination左边,并返回这个元素的值)
应用场景:当source和destination相同时,会不断将队尾元素移到队首,借助这个特性我们可以实现一个网站监控系统:使用一个队列存储需要监控的网址,然后监控程序不断地使用RPOPLPUSH命令循环取出一个网址来测试可用性。这里使用RPOPLPUSH命令的好处在于在程序执行过程中仍然可以不断地向网址列表中加入新网址,而且整个系统容易扩展,允许多个客户端同时处理队列。