redis字符串实现方式

redis字符串实现方式

概念

redis的常用数据结构:string,list,set,zset,hash
redis构建了一个叫做简单动态字符串(Simple Dynamic String)的数据结构,简称SDS.

SDS代码结构

struct sdshdr{
    //  记录已使用长度
    int len;
    // 记录空闲未使用的长度
    int free;
    // 字符数组
    char[] buf;
};

redis的字符串遵守C语言的实现规则,最后一个字符为空字符,并且这个字符不会被计算到length中。

SDS的动态拓展

类似于list

  • 计算大小是否足够
  • 拓展空间至满足所需要的大小
  • 开辟于已使用大小长度相同的空闲free空间

性能优势

  • 快速获取字符串长度
  • 避免缓冲区溢出
  • 降低空间分配提升内存适用效率

对于Redis而言由于每次追加字符串时都会检查空间是否够用,所以不会存在缓冲区溢出问题。

优化措施

1. 空间预分配
对于追加操作,redis不仅会开辟空间至够用而且还会预分配未使用的空间。修改后的字符串长度<1M,分配相同空间,否则分配1M空间
2. 惰性空间回收
适用于字符串缩减操作。redis不会立即回收减少的部分,而是会分配给下一个需要内存的程序。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值