Redis 8大数据结构
1、String
存储整数和字符串,不推荐使用,浪费内存,每次存储都要装箱操作,底层数据结构为数组,两种数据编码格式,具体内容如下图
data:image/s3,"s3://crabby-images/8cbb9/8cbb92d3730b858c11450ca86341d53082c6a8b4" alt=""
2、哈希表(hashes)
在Reids底层哈希表有两种存储方式,ZipList(数组)和HashTable,如果Field的个数超过512个或者Field 中任意一个key或者value的值长度大于64字节会使用HashTable,如下图
data:image/s3,"s3://crabby-images/b2f15/b2f151bb85072fa5c0edb6e7fea5f6b6528233e3" alt=""
3、Set
Set底层数据存储两种存储方式,intzset 和hashtable,如果存在不是数字的值或者数组的长度超过512,数据结构会使用后者,如下图
data:image/s3,"s3://crabby-images/1bfef/1bfefae215832b90f5ed223a4d3133a029d49f15" alt=""
4、ZSet
ZSet底层也是两种存储方式ZipList和跳跃表,如果长度(length)小于128并且value的长度小于64个字节,会使用ZSet,否则使用后者,图结构如下
data:image/s3,"s3://crabby-images/d6340/d6340ae913d7a4815d3a8defe64380d78e363bc8" alt=""
data:image/s3,"s3://crabby-images/b89ab/b89abccbbeb727b8fb8a6ebe909b28d093aa8071" alt=""
5、List
双向链表,数据结构图表如下:
data:image/s3,"s3://crabby-images/2d4d9/2d4d965934176b48d0306bb0371fbb7f3a990e87" alt=""
6、BitMaps
7、hyperKloglogs
8、Streams