Redis---动态字符串,链表,字典(数据结构)

SDS

Redis构建了一种简单动态字符串,simple dynamic string , SDS,用作默认字符串。

结构:

struct sdshdr{

int len; //记录buf数组中已使用字节的数量

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

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

}

SDS和C字符串的区别

1:获取字符串长度的复杂度

C语言通过遍历字符串获取长度,SDS有 字段 len专门表示。 两者时间复杂度分别是 O(n) ,O(1)

2:杜绝缓存区溢出

动态修改内存,检查到所需空间内存不够会进行扩展=

3:减少修改字符串时带来的内存重分配次数

通过 空间预分配和 惰性空间释放 两种方法

4:采用二进制编码比较安全

 

链表

链表提供了高效的节点重排能力,以及顺序性的节点访问方式,并可以通过增删节点调整链表长度。发布订阅,慢查询,监视器也都用到了链表,并且Redis服务器也使用链表保存客户端的状态信息,以及使用链表构建客户端输出缓冲区。

链表节点结构:

typedef struct listNode{

//前置节点

struct listNode * prev;

//后置节点

struct listNode * next;

//节点的值

void * value;

} listNode;

链表结构:

typedef struct list{ <

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值