Redis之link 链表结构

lpush key value

作用: 把值插入到链接头部

rpop key

作用: 返回并删除链表尾元素

rpush,lpop道理同上

lrange key start stop

作用: 返回链表中[start ,stop]中的元素

规律: 左数从0开始,右数从-1开始

lrem key count value

作用: 从key链表中删除 value值

注: 删除count的绝对值个value后结束

Count>0 从表头删除

Count<0 从表尾删除

ltrim key start stop

作用: 剪切key对应的链接,切[start,stop]一段,并把该段重新赋给key

lindex key index

作用: 返回index索引上的值,

如  lindex key 2

llen key

作用:计算链接表的元素个数

redis 127.0.0.1:6379> llen task

(integer) 3

linsert keyafter|before search value

作用: 在key链表中寻找’search’,并在search值之前|之后,.插入value

找到searchValue,返回link的新长度

如果没有找到searchValue,返回-1

如果key不存在或为空列表,返回0

注: 一旦找到一个search后,命令就结束了,因此不会插入多个value

rpoplpush source dest                                                                                                                                                                                                                           

作用: 把source的尾部拿出,放在dest的头部,

并返回 该单元值

 

场景: task + bak双链表完成安全队列

Task列表                          

 

 

 

 

      

bak列表      





业务逻辑:

1:Rpoplpush task bak

2:接收返回值,并做业务处理

3:如果成功,rpop bak 清除任务. 如不成功,下次从bak表里取任务

brpop /blpop key [key ...]timeout

作用:等待弹出key的尾/头元素,

Timeout为等待超时时间

如果timeout为0,则一直等待

BLPOP是列表的阻塞式(blocking)弹出原语。它是LPOP 命令的阻塞版本,当给定列表内没有任何元素可供弹出的时候,连接将被BLPOP 命令阻塞,直到等待超时或发现可弹出元素为止。当给定多个key 参数时,按参数 key 的先后顺序依次检查各个列表,弹出第一个非空列表的头元素并结束命令。

brpop:阻塞弹出队列尾部的元素,不再单述

场景: 长轮询Ajax,在线聊天时,能够用到





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 19
    评论
在 Java 中使用 Redis 实现双向链表需要使用 Redis 的 List 数据结构。List 数据结构Redis 中是一个双向链表,可以通过 Redis 的命令实现双向链表的操作。 下面是一个简单的 Java 实现双向链表的示例代码: ```java import redis.clients.jedis.Jedis; public class RedisLinkedList { private Jedis jedis; private String key; public RedisLinkedList(String key) { jedis = new Jedis("localhost"); this.key = key; } public void addFirst(String value) { jedis.lpush(key, value); } public void addLast(String value) { jedis.rpush(key, value); } public String getFirst() { return jedis.lindex(key, 0); } public String getLast() { long lastIndex = jedis.llen(key) - 1; return jedis.lindex(key, lastIndex); } public String removeFirst() { return jedis.lpop(key); } public String removeLast() { return jedis.rpop(key); } public void printList() { System.out.print("List: "); for (String value : jedis.lrange(key, 0, jedis.llen(key) - 1)) { System.out.print(value + " "); } System.out.println(); } public static void main(String[] args) { RedisLinkedList list = new RedisLinkedList("mylist"); list.addFirst("1"); list.addLast("2"); list.addLast("3"); list.printList(); String first = list.removeFirst(); System.out.println("Removed first element: " + first); list.printList(); String last = list.removeLast(); System.out.println("Removed last element: " + last); list.printList(); System.out.println("First element: " + list.getFirst()); System.out.println("Last element: " + list.getLast()); } } ``` 在这个示例中,我们使用 Jedis 作为 Redis 的 Java 客户端,定义了一个 RedisLinkedList 类来封装 Redis 的 List 数据结构。在 RedisLinkedList 类中,我们通过 Jedis 的 lpush、rpush、lindex、llen、lpop、rpop 和 lrange 方法来实现双向链表的操作。在 main 方法中,我们对 RedisLinkedList 类进行了简单的测试。
评论 19
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值