SDS与C字符串的区别

根据传统, C 语言使用长度为 N+1 的字符数组来表示长度为 N 的字符串, 并且字符数组的最后一个元素总是空字符 '\0' 。

区别1:

C 字符串并不记录自身的长度信息,获取一个C字符串的长度,必须遍历整个字符串,对遇到的字符进行计数,直到遇到代表字符串结尾的空字符为止,复杂度为O(n)

SDS 在len属性中记录了SDS的本身长度,复杂度为O(1)

区别2:

C字符串不记录自身长度容易造成缓冲区溢出

SDS 的空间分配策略完全杜绝了发生缓冲区的可能性:当SDS API 需要对SDS进行修改时,API会先检查SDS的空间是否满足修改所需的要求,如果不满足的话,API会自动将SDS的空间扩展至执行修改所需的大小,然后才执行实际的修改操作,所以使用SDS既不需要修改SDS的空间大小,也不会出现前面所说的缓冲区溢出问题。

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

C字符串的长度和底层数组的长度之间存在这种关联性,所以每次增长或者缩短一个C字符串,总要对保存C字符串的数组进行一次内存重分配操作

在SDS中,buf数组的长度不一定就是字符数量加一,数组里面可以包含为使用的字节,而这些字节的数量就由SDS的free属性记录。通过未使用空间,SDS实习了空间预分配和惰性空间释放两种优化策略.

区别3:二级制安全

C字符串必须符合某种编码,并且除了字符串的末尾之外,字符串里面不能包含空字符。

SDS的API都是二进制安全的,所有SDS API都会以处理二进制的方式来处理SDS存放在buf数组里的数据

区别4:兼容部分C字符串函数

详细区分:

SDS与C字符串的区别_第1张图片
图1

参考地址:http://redisbook.com/preview/sds/different_between_sds_and_c_string.html  





























你可能感兴趣的:(SDS与C字符串的区别)