redis源码学习笔记

今日起,阅读redis源码,话不多说,下载源码..................ok,开始。

目录

1:从数据结构开始(图为源码,附带个人简单分析):


1:从数据结构开始(图为源码,附带个人简单分析):

A:动态字符串         文件: sds.h sds.c

前言:s-(sizeof(struct sdshdr))的解释为buf为柔性数组,不占用空间,仅仅为偏移量,所以s指针向后退一个结构体大小为结构体地址所在。

分析:

这个结构是整个动态字符串的基础,sds为 sdshdr的buf指针,根据buf找到结构体的地址,操作成员len。


分析:

依据init 生成一个新的动态字符串

const void *init 为初始化字符串指针, initlen为字符串大小

如果init为空则初始化开辟的initlen大小buf的初始化为0的内存。

不空则拷贝init至buf,返回buf地址

 


改变buf内存大小,扩增

如果扩增的addlen+len大于1024*1024则新长度为1024*1024

realloc修改内存大小

返回buf地址

 


释放free空间,将动态数组总长度设置为len+1,free为0;


在free空间中划出inc大小的空间,放到len空间中;


 

此函数为设置动态字符数组->len大小设置为参数len,先从free空间补,若是不够,则重新分配数组大小。


动态字符串追加函数,t为追加的字符串,len为追加字符串的长度。扩展s的len,memcpy;


字符串拷贝函数,依然先判断free大小是否足够。不够则重新分配大小。


在学习此函数之前先了解一下基础知识;

vsnprintf函数

头文件:#include  <stdarg.h>

函数原型:int vsnprintf(char *str, size_t size, const char *format, va_list ap);

函数说明:将可变参数格式化输出到一个字符数组

参数:str输出到的数组,size指定大小,防止越界,format格式化参数,ap可变参数列表

========================

此函数是将格式化输入当做是动态字符串的字符指针指向的值(追加值);


这个函数我的理解是,把s中的字符cset集合从两头剔除,中间部分可能不被删除。

strchr为找到参数1中第一次出现参数2的位置。

用sp记录cset首部字符个数,ep记录cset尾部字符个数,ep-sp为裁剪之后的字符串长度,

memove裁剪后的内容。


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值