相比于C字符串,SDS的优势:
- O(1)获取字符串的长度
- 不会缓冲区溢出
- 减少修改字符串时所需的内存重新分配的次数(空间预分配、惰性空间释放)
- 二进制API安全(通过len获取长度)
- 兼容部分C字符串函数
Redis hash策略
1. Redis中的字典使用哈希表作为底层,每个字典带有两个哈希表,一个平时使用,另一个仅在rehash的时候使用
2. 字典作为数据库或者哈希键的底层实现时,Redis使用MurmurHash2算法来计算键的哈希值
3. 哈希表使用链地址法来解决哈希冲突,被分配到同一个键值上的多个索引会链接形成一个单向链表
4. 在对哈希表进行扩展或者收缩时,rehash过程不是一次完成,而是渐进式完成
embstr
和raw
embtr
优势:
embstr
编码将创建字符串对象所需的内存分配次数从raw
的两次降低为一次。- 同样,释放
embstr
编码的字符串对象只需要调用一次内存释放函数,而raw
需要两次。 embstr
编码所保存的所有数据都在同一块连续的内存里,而raw
编码中的redisObject
和sdshdr
则是分别存储的,这样能更好地利用缓存的优势。
embstr
编码实际上只读的,所以当我们对embstr
编码的字符串对象执行修改命令时,会先将其修改为raw
字符串对象再进行修改。
注:字符串对象是Redis
中唯一会被其他四种对象嵌套的类型。
最后给大家推荐一个LinuxC/C++高级架构系统教程的学习资源与课程,可以帮助你有方向、更细致地学习C/C++后端开发,具体内容请见 https://xxetb.xetslk.com/s/1o04uB