redis hashmap过期_Redis学习笔记之Redis基本数据结构

本文详细介绍了Redis的五种基本数据结构:String、List、Hash、Set和zSet,包括它们的特点和使用场景。同时提到了Redis如何处理key过期,以及在面试中常见的后台技术问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

走过路过不要错过

点击蓝字关注我们

Redis基础数据结构

Redis有5种基本数据结构:String(字符串)、list(列表)、set(集合)、hash(哈希)、zset(有序集合)

字符串string

字符串类型是Redis的value最简单的数据结构,类似与Java语言中的ArrayList(数字列表),不过在Redis里String是一种动态字符串

Redis里的String采用预分配冗余空间的方法

4a2e6404c5d2a275c58ae3a637961e76.png

set & get

>set keyname testOK>get keynametest//key如果存在就返回0>setnx keyname test0>exists keyname>del keyname1//批量设置>mset key1 test1 key2 test2OK//批量获取>mget key1 key21) test12) test2

key过期

//设置5s后过期>expire keyname 5//setex是expire和set的复合写法>setex keyname 5 testOK//5s后查询>get keynameNULL

计数ps:value为数字的情况,可以使用incr和incrby计数

>set num 10OK//incr默认加1>incr num11//incrby后面要加上数字>incrby numERR wrong number of arguments for 'incrby' command//正确计数>incrby num 516
列表list

下面介绍一下redis的另外一种数据结构list
前面我们说redis里的string类似与java语言里面的ArrayList,则redis里的列表就类似与LinkList(链表),链表一个特别就是更新和新增特别快,查询索引慢。

为什么说类似与linklist?因为redis的list并非和linklist一样,它其实是一种快速列表(quicklist)的形式,列表结构如图:

454728d3ca9673e00dd2974ef8975754.png

这里要介绍一下压缩列表(ziplist)了,压缩列表是什么?其实就是连续的内存空间

从图可以看出快速列表其实就是由压缩列表和双向的指针组成,不过我们知道链表是两个指针的,也就是prev和next执行,这就是快速列表和linklist的一个不同点了。

PS:然后redis设计时,为什么改成双向指针?假如和链表一样,用两个指针prev、next,同样可以实现遍历,不过双向指针有一个很明显的优点,就是占用的内存空间就相对少了。

队列和栈

/* 队列:First in first out *///加两个value>rpush keynames key1 key22//计算>llen keynames2>lpop keynameskey1>lpop keynameskey2//rpush会自动过期的>rpop keynamesNULL/* 栈:First in last out *///同样,加两个元素>rpush keynames key1 key22>rpop keynameskey2>rpop keynameskey1
字典hash

Redis的字典类似与java语言的hashmap,也是无序的二维结构,也即数组加列表的结构。这是redis字典和hashmap类似的地。

然后也有不同,比如rehash,刷新字典操作,hashmap是全部热hash,当字典足够多时,性能不是很好的,所以redis进行改造,采用渐进式的方式,为什么说是渐进式?因为redis不会全部reload,而是保存新旧两个字典,然后采用定时任务,将旧hash的数据搬到新的hash,搬后在回收hash内存空间

字典(hash)的数组加链接结构:

ab036d9bb14f059c354060376e173b12.png

>hset keynames key1 "test1"1>hset keynames key2 "test2"1//批量set>hmset keynames key1 "test1" key2 "test2"OK//获取key1的值>hget keynames key1test1//获取hash为keynames的长度>hlen keynames2//获取全部>hgetall keynames1) key12) test13) key24) test2
集合set

redis的set和java语言中的hashset类型,是一种无序唯一的。

>sadd keynames key11//key1已经加过了,所以返回1>sadd keynames key1 key21>smembers keynames1) key22) key1//查询某个key是否存在,相当与contains>sismember keynames key11//相当于count>scard keynames2//随意弹出key1>spop keynameskey1
有序集合zSet

有序集合是redis里比较有特色的,它类似于SortedSet和HashMap的组合。其内部实现是一种被称作跳跃列表的数据结构。有序集合一方面它就是一个set,所以每个元素都是唯一的,然后它可以给每个value赋值一个score,再根据这个score进行排序,score就相当于一个权限排序的标识。

ps:因为这个原因,有序集合可以被用来存储粉丝信息,value值是粉丝id,score是关注时间

//9.0是score也就是权重>zadd keyname 9.0 math1>zadd keyname 9.2 history1//顺序>zrange keyname 0 -11) history2) math//逆序>zrevrange keyname 0 -11) math2) history//相当于count()>zcard keyname2获取指定key的score>zscore keyname math9

053d70c1b588bdceefe800e9ce591398.png往期精彩推荐

腾讯、阿里、滴滴后台面试题汇总总结 — (含答案)

面试:史上最全多线程面试题 !

最新阿里内推Java后端面试题

JVM难学?那是因为你没认真看完这篇文章

9071c0318edf9a7e93da09bf698b9722.png—END—

关注作者微信公众号 —《JAVA烂猪皮》

了解更多java后端架构知识以及最新面试宝典

4ebf60a63de89dd24d961e53bb79b1bc.png

3b7c886512ccbaa690022f5d294cb3c2.png你点的每个好看,我都认真当成了c79556991a4a770295deb4b044574849.png

看完本文记得给作者点赞+在看哦~~~大家的支持,是作者源源不断出文的动力

作者:SmileNicky

出处:https://www.cnblogs.com/mzq123/p/9710608.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值