Redis相关知识汇总(三)数据类型之hash和set

本文介绍了Redis中的Hash和Set数据类型。Hash内部结构类似dict,受限于配置参数,适用于存储对象。Set分为两种内部结构,一种是OBJ_ENCODING_HT,仅使用key;另一种是OBJ_ENCODING_INTSET,用于存储纯数字,采用有序的二分查找插入。当Set包含字符串时,会转换为Hash。

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

很抱歉, 标识出错了,下面的k代表的是字节,b代表的bit, 不要被我图中误导
hash

我感觉hash没啥好说的, 直接上图就好了,内部就是一个dict。
在这里插入图片描述
值得注意的地方, hash是有限制的:
redis.conf
hash-max-ziplist-value 64 // ziplist中最大能存放的值长度
hash-max-ziplist-entries 512 // ziplist中最多能存放的entry节点数量


应用场景:
对象


set

set 内部有两种数据结构:

  1. 采用的是跟hash(OBJ_ENCODING_HT)的结构存储值, 区别在于, 只用到了key。如图:在这里插入图片描述
  2. 第二种是纯数字的set, 他采用了 OBJ_ENCODING_INTSET 的存储方式

在这里插入图片描述
纯数字他又分了3编码, 用来存放不同大小的数字:
在这里插入图片描述
初始化的时候是 INTSET_ENC_INT16, 如果增加的数字类型比 INTSET_ENC_INT16 大, 会根据类型,改变成 INTSET_ENC_INT32 或者 INTSET_ENC_INT64。
在这里插入图片描述
插 入 的 位 置 并 不 是 向 我 图 中 画 的 那 样 , 他 采 用 的 是 \color{red} 插入的位置并不是向我图中画的那样, 他采用的是 二分查找 的 形 式 先 找 到 一 个 可 插 入 点 p o s \color{red} 的形式先找到一个可插入点pos pos
然 后 开 辟 内 存 , 再 偏 移 到 p o s , 右 移 p o s 右 边 的 所 有 数 字 , 最 后 给 p o s 指 向 地 址 的 值 赋 值 \color{red} 然后开辟内存,再偏移到pos, 右移pos右边的所有数字,最后给pos指向地址的值赋值 pos,pospos
所 以 i n t s e t 是 有 序 的 , 是 一 个 从 小 到 大 的 数 组 , 但 是 H A S H 是 无 序 的 \color{green} 所以intset是有序的, 是一个从小到大的数组,但是 HASH 是无序的 intsetHASH
当插入字符串的时候, inset 就自动转成 HASH(OBJ_ENCODING_HT)

sorted_set

跳跃表, 这里先留个坑。以后再整理。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值