redis 版本

[root@localhost ~]# redis-server --version
Redis server v=2.8. sha=: malloc=jemalloc-3.6. bits= build=e2559761bd460ca0

list 是一个链表结构,主要功能是 push(类似 PHP 的 array_push() 方法)、 pop(类似 PHP 的 array_pop() 方法)、获取一个范围的所有值 等, 操作

中 key 理解为链表的名字。Redis 的 list 类型其实就是一个每个子元素都是 string 类型的 双向链表

链表的最大长度是(2的 32 次方)。我们可以通过 push, pop 操作从链表的头部或者尾部添加删除元素。这使得 list 既可以用作栈,也可以用作队列

有意思的是 list 的 pop 操作还有阻塞版本的,当我们[lr]pop 一个 list 对象时,如果 list 是空,或者不存在,会立即返回 nil。但是阻塞版本的 b[lr]pop 可以则可以阻塞,当然可以加超时时间,超时后也会返回 nil。为什么要阻塞版本的 pop 呢,主要是为了避免轮询。举个简单的例子如果我们用 list 来实现一个工作队列。执行任务的 thread 可以调用阻塞版本的 pop 去获取任务这样就可以避免轮询去检查是否有任务存在。当任务来时候工作线程可以立即返回,也可以避免轮询带来的延迟。

lpush 方法(

在 key 对应 list 的头部 添加(压入)字符串元素。

lrange 方法

lrange list1 0 -1 代表从链表 list1 的头部第一个元素取到 尾部第一个元素(-1 代表尾部第一个元素)。

【例】

127.0.0.1:> lpush list1 hello
(integer) 1 127.0.0.1:> lpush list1 world
(integer) 2 127.0.0.1:> lrange list1 -
) "world"
) "hello"

rpush 方法(队列

在 key 对应 list 的尾部 添加(压入)字符串元素。

【例】

127.0.0.1:> rpush list2 hello
(integer) 1 127.0.0.1:> rpush list2 world
(integer) 2 127.0.0.1:> lrange list2 -
) "hello"
) "world"

不论是 lpush 还是 rpush 方法,都是从 list 的 两端压入

linsert 方法

在 key 对应 list 的特定位置前或后添加字符串。

【例】

127.0.0.1:> rpush list3 one
(integer) 127.0.0.1:> linsert list3 before one two
(integer) 127.0.0.1:> lrange list3 -
) "two"
) "one" 127.0.0.1:> linsert list3 before one three
(integer) 127.0.0.1:> lrange list3 -
) "two"
) "three"
) "one"

注意:

|   |  头(前)

|   |  ↑

|   |  尾

lset 方法

设置 list 中指定下标的元素值(替换指定下标的元素,类似 PHP 中的数组:$arr = array('a', 'b', 'c'); $arr[0] = 'd'; )。

【例】

127.0.0.1:> lrange list3  -
) "two"
) "three"
) "one" 127.0.0.1:> lset list3 tmp
OK
127.0.0.1:> lrange list3 -
) "two"
) "tmp"
) "one" 127.0.0.1:> lset list3 reset
OK
127.0.0.1:> lrange list3 -
) "reset"
) "tmp"
) "one"

lrem 方法

从 key 对应 list 中删除 n 个和 value 相同的元素。(n < 0 从尾删除,n = 0 全部删除)。返回删除的个数。

【例】

127.0.0.1:> lrange list3  -
) "reset"
) "tmp"
) "one" 127.0.0.1:> lpush list3 two
(integer)
127.0.0.1:> lpush list3 two
(integer)
127.0.0.1:> lpush list3 two
(integer) 6 127.0.0.1:> lrange list3 -
) "two"
) "two"
) "two"
) "reset"
) "tmp"
) "one" 127.0.0.1:> lrem list3 two
(integer) 1 127.0.0.1:> lrange list3 -
) "two"
) "two"
) "reset"
) "tmp"
) "one" 127.0.0.1:> rpush list3 two
(integer) 6 127.0.0.1:> lrange list3 -
) "two"
) "two"
) "reset"
) "tmp"
) "one"
) "two" 127.0.0.1:> lrem list3 - two
(integer) 2 127.0.0.1:> lrange list3 -
) "two"
) "reset"
) "tmp"
) "one"

【例2】

127.0.0.1:> lrange list3  -
) "two"
) "reset"
) "tmp"
) "one" 127.0.0.1:> lrem list3 - two
(integer) 1 127.0.0.1:> lrange list3 -
) "reset"
) "tmp"
) "one" 127.0.0.1:> lrem list3 - two
(integer) 0 127.0.0.1:> lrange list3 -
) "reset"
) "tmp"
) "one"

ltrm 方法

保留指定 key  的值范围内的数据。

【例】

127.0.0.1:> lpush list4 one
(integer)
127.0.0.1:> lpush list4 two
(integer)
127.0.0.1:> lpush list4 three
(integer)
127.0.0.1:> lpush list4 four
(integer)

127.0.0.1:> lrange list4 -
) "four"
) "three"
) "two"
) "one" 127.0.0.1:> ltrim list4
OK
127.0.0.1:> lrange list4 -
) "three"
) "two"

说明:保留下标(key)为 1 开始到下标为 2 的元素,其他两端的元素全部删除。

【例2】

127.0.0.1:> lrange list4  -
) "seven"
) "six"
) "five"
) "three"
) "two" 127.0.0.1:> ltrim list4 -
OK
127.0.0.1:> lrange list4 -
) "five"
) "three"
) "two"

lpop 方法

从 list 的头部 删除 元素,并返回删除的元素(类似 PHP 中的 array_pop() 方法:将数组的最后一个单元弹出(删除))。

rpop:代表从尾部删除元素)

【例】

127.0.0.1:> lrange list4  -
) "five"
) "three"
) "two" 127.0.0.1:> lpop list4
"five" 127.0.0.1:> lrange list4 -
) "three"
) "two" 127.0.0.1:> rpop list4
"two" 127.0.0.1:> lrange list4 -
) "three"

rpoplpush 方法

从第一个 list 的尾部移除元素并添加到 第二个 list 的头部。

127.0.0.1:> lrange list4  -
) "eight"
) "seven"
) "three" 127.0.0.1:> lrange list5 -
) "redis"
) "nginx"
) "mysql"
) "php" 127.0.0.1:> rpoplpush list4 list5
"three" 127.0.0.1:> lrange list4 -
) "eight"
) "seven" 127.0.0.1:> lrange list5 -
) "three"
) "redis"
) "nginx"
) "mysql"
) "php"

lindex 方法

返回名称为 key 的 list 中 index 位置的元素。

【例】

127.0.0.1:> lrange list5  -
) "three"
) "redis"
) "nginx"
) "mysql"
) "php" 127.0.0.1:> lindex list5
"redis" 127.0.0.1:> lindex list5 -
"php"

llen 方法(类似 PHP 中 count($arr) )

返回 list 链表中元素的个数。

【例】

127.0.0.1:> lrange list5  -
) "three"
) "redis"
) "nginx"
) "mysql"
) "php" 127.0.0.1:> llen list5
(integer)

 

Redis 笔记与总结3 list 类型的更多相关文章

  1. Redis 笔记与总结2 String 类型和 Hash 类型

    Linux 版本信息: cat /etc/issue 或cat /etc/redhat-release(Linux查看版本当前操作系统发行版信息) CentOS release 6.6 (Final) ...

  2. 【Redis笔记(四)】 Redis数据结构 - list链表

    原创作品,转载请标明:http://blog.csdn.net/Xiejingfa/article/details/50573605 经过前面的介绍,我们学习了Redis中string字符串.hash ...

  3. Redis 笔记 01:入门篇

    Redis 笔记 01:入门篇 ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ...

  4. Redis笔记(六)Redis的消息通知

    Redis的消息通知可以使用List类型的LPUSH和RPOP(左进右出),当然更方便的是直接使用Redis的Pub/Sub(发布/订阅)模式. >>使用List实现队列 使用列表类型的L ...

  5. 【redis】02string类型和hash类型

    Redis的数据类型   Redis主要分为五个数据类型,一个是string,最简单的一个数据类型,hash,list, 还有set集合,还有zset有序集合,这是咱们redis的五种基础类型, 接下 ...

  6. JavaScript高级程序设计之自学笔记(一)————Array类型

    以下为自学笔记. 一.Array类型 创建数组的基本方式有两种: 1.1第一种是使用Array构造函数(可省略new操作符). 1.2第二种是使用数组字面量表示法. 二.数组的访问 2.1访问方法 在 ...

  7. Redis笔记(七):Redis应用场景

    特性优势 1 支持持久化 Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用. 2 数据类型丰富 Redis不仅仅支持简单的key-value类型的数据,同时还 ...

  8. Redis笔记(二):Redis数据类型

    Redis 数据类型 Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合). String(字符串) st ...

  9. Redis笔记(一):Redis安装教程

    Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. Redis是目前应用最广泛的内存数据存储技术,相比之前的Me ...

随机推荐

  1. 使yum保留下载的rpm包

    [root@14LN yum]# egrep 'cachedir|keepcache' /etc/yum.conf #cachedir=/var/cache/yum/$basearch/$releas ...

  2. 在Android软按键中添加Menu键

    在Android中,有时候没有硬件Menu.于是需要软件Menu.但是默认Google想让你用ActionBar上的Menu. 但是,有时候我们确实需要在在底部的软按键上加Menu.这里提供一种方法, ...

  3. 用PHP实现定时器功能

    1.直接使用PHP来完成定时 <?php ignore_user_abort(false);//当用户关闭页面时服务停止 set_time_limit(0); //设置执行时间,单位是秒.0表示 ...

  4. DataSet与Xml文件的互相转换

    DataSet转换为xml文件   //将DataSet转换为xml文件        private static void ConvertDataSetToXMLFile(DataSet xmlD ...

  5. 【bzoj1051】 [HAOI2006]受欢迎的牛 tarjan缩点判出度算点数

    [bzoj1051] [HAOI2006]受欢迎的牛 2014年1月8日7450 Description 每一头牛的愿望就是变成一头最受欢迎的牛.现在有N头牛,给你M对整数(A,B),表示牛A认为牛B ...

  6. poj 1935(树形dp)

    题目链接:http://poj.org/problem?id=1935 思路:首先我们考虑从源点出发到所有自己想要经过的点然后在回到源点sum,显然每条边都必须经过源点(这个我们可以一次dfs求出), ...

  7. Activity使用Serializable传递对象实例

    public class SerializableBook implements Serializable { private static final long serialVersionUID = ...

  8. 【转】reduce端缓存数据过多出现FGC,导致reduce生成的数据无法写到hdfs

    转自  http://blog.csdn.net/bigdatahappy/article/details/41726389 转这个目的,是因为该贴子中调优思路不错,值得学习 搜索推荐有一个job,1 ...

  9. javascript优化--01高质量编码

    javascript的浮点数: Javascript的数字都是双精度浮点数: 64位编码数字: 能表达53位精度的整数: 进行位运算时会隐式地转化为32位整数(0,1序列)后计算: 浮点数运算可能会有 ...

  10. HDU2841 Visible Trees(容斥原理)

    题目..大概就是有个m*n个点的矩形从(1,1)到(m,n),问从(0,0)出发直线看过去最多能看到几个点. 如果(0,0)->(x,y)和(0,0)->(x',y')两个向量平行,那后面 ...