redis简单动态字符串

Redis的简单字符串结构包含free字段记录未使用空间,len字段记录使用长度,buf存储值并以''结尾。增长策略为:长度小于1M时分配len*2的空间,大于1M时分配len+1M的空间。这种设计允许常数复杂度获取长度,避免缓冲区溢出,确保二进制安全,并减少内存分配次数。

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

redis简单字符串的结构如下:

sdshdrint lenint freechar buf

其中free存储当前已经分配但是没有使用的空间
len存储当前使用的字符串长度
buf存储当前的值,并以’\0’结尾

所以,buf的总长度是len+free+1

redis字符串的增长策略

  • 当字符串长度小于1M时,分配len*2的新空间
  • 当字符串长度大于1M时,分配len+1M的新空间

redis这样做的好处

  1. 常数复杂度获取字符串长度
  2. 进行字符串连接时,通过判断free杜绝缓冲区溢出
  3. 二进制安全(用len标示长度,而不是特殊的字符)
  4. 预分配内存减少内存分配次数
  5. 兼容c字符串
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值