承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

redis列表类型_动力节点Java学院整理

管理员 2023-05-23 08:36:31 网站建设 25 ℃ 0 评论 3436字 收藏

听说60%的人使用redis看重的是redis中的list类型,那这个list有甚么用呢???不用我说大家都明白,做队列使用呗,为何用它呢,很简单呗,由于有了它我就不需要专门的MQ产品啦,比如说RabbitMQ,ActiveMQ等等。。。对吧。

一、实战

先我们或者看一下List列表给我们提供的方法。

这些方法或者莫名其妙的有一些的,没关系,做队列使用的话,经常使用的也就四个:LPOP,LPUSH,RPOP,RPUSH,从这四个单词上面,你应当就明白这有点像数据结构中的“双端队列”,对吧,既然我可以在左侧Pop或Push,又可以在右侧Pop或Push,那这样的话,我又可以把List做成队列或堆栈,哈哈,是不是是很成心思,下面我举个例子:我向List的左侧顺序的塞入10,20,30,40,50,然后从队列的另外一头顺次输出10,20,30,40,50。

对了,我就说一下在我们目前的项目中使用list的一些场景吧。

1. 由于项目中使用了大量的wcf,致使配置过量,保护和更新异常繁琐,基于这类情况,我们把wcf可以异步处理的所有要求都丢到了redis的List中去,这样下来以后,web站点的config配置清新的不要不要的。

2. 还有一个业务就是我们做的淘宝定单催付,付款提示,签收提示,收货提示 等等都是采取轮询List的方式,大大下降了代码复杂量。

好了,这个大概就是list的使用处景,下面我们来看下这是怎样实现的。

二、探索原理

源代码是在adlist.c中,以下所示。

是不是是简单的一吊,如果你学过数据结构中的链表,我想你一看便懂:

<1> listNode  

   很明显这是一个node节点,可以看出它有一个prev指针和一个next指针,分别指向节点的先驱和后继,然后还有一个void* 这个类型的value,

它寄存的就是上一篇我们所说的SDS类型的枚举。

<2>list

   这个list蛮成心思的一点就是,里面有一个head和tail节点,可想而知,tail寄存的是list的尾节点,有了这个节点就说明甚么呢?说明你删除尾节点的复杂度是O(1),一样有了这个head,你删除头节点一样也是O(1)。这就有了刚才说的LPush,LPop,RPush,RPop,是的吧,同时list里面还有一个len属性,是记录当前list的元素个数,这样的话,你统计list的个数也是O(1)的,对吧。

RedisObject里面有一个ptr指针,它指向的就是本篇的list,好了,根据种种总结,我应当可以画出以下的图:

本篇文章到此结束,如果您有相关技术方面疑问可以联系我们技术人员远程解决,感谢大家支持本站!

文章来源:丸子建站

文章标题:redis列表类型_动力节点Java学院整理

https://www.wanzijz.com/view/39700.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信