sds是redis本身实现的一种数据结构,用来做为redis底层默认字符串,与c语言的字符串区别开来。
在redis中c字符串通常用于不须要改变的字符串值,叫作字符串字面量,如:打印日志。
redis中每对键值的键都是一个sds对象。redis
传统c字符串与sds比较:算法
避免频繁内存重分配:传统c字符串的长度为n+1(空字符),每一次append时须要从新分配内存,不然内存溢出;若是trim字符串,后面不须要的空间也要释放,不然内存泄露。内存重分配设计复杂算法且可能须要系统调度,不符合redis的速度要求。而sds经过free-未使用空间来解除了底层数组长度与字符串长度间的关联,sds拥有空间预分配与惰性空间释放两钟优化策略。数组