开发者社区 问答 正文

为什么Redis底层使用SDS(Simple Dynamic Strings)结构体而不是C语言原生

为什么Redis底层使用SDS(Simple Dynamic Strings)结构体而不是C语言原生的字符串?

展开
收起
不吃核桃 2024-08-13 23:40:10 39 发布于河南 分享
分享
版权
举报
1 条回答
写回答
取消 提交回答
  • Redis底层使用SDS结构体而不是C语言原生的字符串,主要是因为SDS提供了几个关键的优势:
    低复杂度获取字符串长度:SDS结构体中直接存储了字符串的长度(len),因此可以在O(1)复杂度内获取字符串的长度。而C语言字符串需要遍历整个字符串来计算长度,复杂度为O(n)。

    2024-08-14 08:04:54 举报
    赞同 1 评论

    评论

    全部评论 (0)

    登录后可评论