Redis学习笔记(六)基础数据结构
2021-01-14 本文已影响0人
那些年搬过的砖
一、String键值对
data:image/s3,"s3://crabby-images/ec30e/ec30e64828e724eca103dcbaf1b76b8eaf1b4273" alt=""
二、List——相当于java中的LinkedList
data:image/s3,"s3://crabby-images/56efd/56efdcf85f3d751acf246ed5e43649ce787c1987" alt=""
插入删除时间复杂度O(1)
查询时间复杂度O(n)
实际上redis内部并不是一个简单的linkedlist,而是由多个具有双向指针的ziplist组成的quicklist,ziplist是一块连续的内存空间。
data:image/s3,"s3://crabby-images/d20c3/d20c3bd99545304086e965bfd763eb383ece8c60" alt=""
三、Hash——相当于java中的HashMap
data:image/s3,"s3://crabby-images/fc7a0/fc7a08547f50fa6e2814394b42209b9883c85e3b" alt=""
四、set(无序集合)
set具有去重功能
data:image/s3,"s3://crabby-images/7839e/7839e978517016b2ea9a157d56b97dcc6fb12a92" alt=""
五、zset(有序集合)相当于java中SortedSet和HashMap的结合
1、具有set的特性,即保证了value的唯一性
2、具备按score排序的特性
比如zet可以按下图存储粉丝列表,value代表某用户的粉丝,score表示关注时间。
data:image/s3,"s3://crabby-images/32a74/32a74290714a71cf9a72fcd84bd62c2d66c7186d" alt=""
底层数据结构
假设要把华山论剑各路英雄的武力排行存放到跳跃表中,则存储结构可能是下图这样。特性如下
1、所有元素都存储在L0层
2、部分元素会被抽取到L1层(随机50%)组成稀疏索引
3、部分元素被抽取到L2层(随机25%)组成更稀疏的索引
4、Redis总共设计了32层(最顶层是L31),越往上索引越稀疏
data:image/s3,"s3://crabby-images/f0cbe/f0cbe0c979cb0819431e8f5b838ec307ebadd1f4" alt=""
元素插入和删除时,会先在最上一层查找,然后根据范围依次往下一层下潜,直到找到L0层的具体的位置。