redis的数据结构
String:动态的,类似ArrayList。里边可以是字符串,数字,浮点数
List:每一个节点都有一个字符串,双向链表 0,1,2,3 -1****,-2****,-3
Set:无序字符串
Hash:<key,value> 类似Java里的hashmap
Zset(value,score)排列顺序由score决定===等价于sortedset
data:image/s3,"s3://crabby-images/98904/9890458a14f377eb8bb55a9ccafb44efb55ca66a" alt=""
data:image/s3,"s3://crabby-images/fb5fb/fb5fba45b797fb30debaf957ff1b97cd845d69a6" alt=""
跳跃表
跳表是从上往下找
比如:
要找5
从第二层开始找,发现5在第二层的4和6之间,开始向下找。一直到第四层才找到
用空间找时间,查找效率较高,所以zset用跳表,是利用跳表查找的效率高
因为zset是要根据score进行排序的,取数据时需要排序,但为什么不用平衡二叉树和红黑树呢?
因为平衡二叉树需要不断调整,很麻烦的。实现起来还不如跳表简单
data:image/s3,"s3://crabby-images/d3b06/d3b0615d0e957c873410f0b184286a4299152aa1" alt=""
在实际的实现中,跳跃表内部是双向链表
网友评论