redis:简单动态字符串(SDS)

Redis结构:

struct sdshdr {

    // 记录 buf 数组中已使用字节的数量
    // 等于 SDS 所保存字符串的长度
    int len;

    // 记录 buf 数组中未使用字节的数量
    int free;

    // 字节数组,用于保存字符串
    char buf[];

};

为什么要自己定义SDS:

C语言字符串有以下几个问题:

1.计算字符串的长度时间复杂度为O(n)。
2.每一次删除和增加字符串的长度,都需要重新分配空间。
3.缓存区异常
4.类似ASCII码,字符串中不能出现空白符。否则认为是字符串的结尾。

redids改进:

1.redis的结构中存储了字符串的长度,所以获取字符串的长度的时间复杂的为O(1)
2.由于redis分配的空间不是按照需要的分配,一般会有多余的空间。所以
字符串长度增加时,剩余的空间足够,就可以避免重新分配空间。减少字符的长度时也不是直接删除多余的内容。而是设置已使用空间的长度,隐藏删除内容。
3.redis会先检查总的空间大小,满足才会分配
4.采用二进制存储,不存在空白符的干扰

什么是C语言缓冲区溢出

#include <stdio.h>
#include <string.h>
int main(void)
{
    char buff[8] = {0};
    char *p = "0123456789";
    //buff长度是8,而p的长度是10。运行时控制台会报错提示:
    //stack smashing detected
    strcpy(buff,p);
    printf("%s\n",buff);
    return 0;

参考
https://zhuanlan.zhihu.com/p/44215098

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值