目录
C字符串
SDS(动态字符串)
区别
总结
首页 数据库 Redis 浅谈Redis SDS跟C字符串的区别

浅谈Redis SDS跟C字符串的区别

Apr 29, 2021 am 11:00 AM
redis sds

本篇文章给大家介绍一下Redis SDS动态字符串跟C字符串的区别。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

浅谈Redis SDS跟C字符串的区别

redis底层没有使用“C字符串”来表示,而是用自己构建的“SDS抽象类型”进行默认字符串表示。【相关推荐:Redis视频教程

C字符串

C字符串储存的数据,最后会有一个空字符结尾. 举个例子,比如说 "redis" 他实际的形式就是  'R' 'E' 'D' 'I' 'S' '\0'

SDS(动态字符串)

SDS 是 redis 构建的一种抽象类型,主要用于储存 redis 的默认字符串表示、AOF 模块中的 AOF 缓冲区、客户端状态输入缓冲区。

SDS抽象类型内容有:

  • int len, 用来记录字符串的长度

  • int free, 用来记录buf数组中未使用的字节的数量

  • char buf[],字节数组用来保存字符串

SDS结构如下图所示

image.png

区别

1、在求长度的时候

C字符串要进行遍历才可以知道该字符串的长度 复杂度 O(n).

SDS只需要访问内部的len属性即可 时间复杂度O(1).

2、缓冲区溢出问题

C字符串 设置了一个S1为 “redis” ,但是底层有一个跟他相邻的S2为“abc”,然后这里如果通过函数 strcat 把S1拼接S3 "ccc",然后最后结果应该是 “redisccc”, 但是如果本身给S1设置内存不够的话,这样会导致把与它相邻的S2进行修改。

SDS 这里会先根据空间是否够用,不够则扩展空间到够位置,并且会多添加len长度的free未使用的空间,比如说redis字符串的长度为5,然后还会空间预分配同等的长度5,最后实际空间长度为 free + len + 1 为 10。

3、字符串内存分配

c字符串,当给某个字符串加数据或减少数据的时候, 就会重新申请内存 但是如果过多的申请必然会导致性能的下降,更改N次则分配N次。

SDS 内部使用两种机制 惰性空间释放跟空间预分配

空间预分配:

  空间预分配:指当我们进行一次空间分配以后,我们会在原有基础上再多分配len长度的空间

  这里SDS长度小于1M的时候是 free = len,举个例子若SDS长度为 6byte 则实际的空间为 6byte + 6byte + 1byte

  大于1M的时候只会多分配1M。free = 1M, 举个例子若SDS长度为60M 则实际空间为 60M + 1M + 1byte

惰性空间释放

  当我们对某个字符串进行减少的时候,程序并不立即使用内存重新分配来回收缩短后的字节,而是通过free记录起来,以供后续使用,SDS也提供了相应的API,防止惰性空间导致内存浪费。

4、二进制安全

c字符串最后是由空字符结尾,但是如果有些特殊的数据需要空字符,会导致数据无法保存会导致提前识别第一个空字符之前的数据。 SDS 因为SDS是根据长度来进行识别字符串的所以可以保证数据的正确。

5、兼容部分C语言的函数 因为SDS也遵循C的以空字符为结尾,所以它可以使用C里面的一些函数

总结

image.png

一边学习一边记录笔记, 加深记忆,加油,若有什么问题请指出,在此谢过。

更多编程相关知识,请访问:编程视频!!

以上是浅谈Redis SDS跟C字符串的区别的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

redis集群模式怎么搭建 redis集群模式怎么搭建 Apr 10, 2025 pm 10:15 PM

Redis集群模式通过分片将Redis实例部署到多个服务器,提高可扩展性和可用性。搭建步骤如下:创建奇数个Redis实例,端口不同;创建3个sentinel实例,监控Redis实例并进行故障转移;配置sentinel配置文件,添加监控Redis实例信息和故障转移设置;配置Redis实例配置文件,启用集群模式并指定集群信息文件路径;创建nodes.conf文件,包含各Redis实例的信息;启动集群,执行create命令创建集群并指定副本数量;登录集群执行CLUSTER INFO命令验证集群状态;使

redis底层怎么实现 redis底层怎么实现 Apr 10, 2025 pm 07:21 PM

Redis 使用哈希表存储数据,支持字符串、列表、哈希表、集合和有序集合等数据结构。Redis 通过快照 (RDB) 和追加只写 (AOF) 机制持久化数据。Redis 使用主从复制来提高数据可用性。Redis 使用单线程事件循环处理连接和命令,保证数据原子性和一致性。Redis 为键设置过期时间,并使用 lazy 删除机制删除过期键。

redis-server找不到怎么办 redis-server找不到怎么办 Apr 10, 2025 pm 06:54 PM

解决redis-server找不到问题的步骤:检查安装,确保已正确安装Redis;设置环境变量REDIS_HOST和REDIS_PORT;启动Redis服务器redis-server;检查服务器是否运行redis-cli ping。

redis集群是如何实现的 redis集群是如何实现的 Apr 10, 2025 pm 05:27 PM

Redis集群是一种分布式部署模式,允许水平扩展Redis实例,通过节点间通信、哈希槽划分键空间、节点选举、主从复制和命令重定向来实现:节点间通信:通过集群总线实现虚拟网络通信。哈希槽:将键空间划分为哈希槽,确定负责键的节点。节点选举:至少需要三个主节点,通过选举机制确保仅有一个活动主节点。主从复制:主节点负责写请求,从节点负责读请求和数据复制。命令重定向:客户端连接到负责键的节点,节点重定向不正确的请求。故障处理:故障检测、标记下线和重新

redis如何查看版本号 redis如何查看版本号 Apr 10, 2025 pm 05:57 PM

要查看 Redis 版本号,可以使用以下三种方法:(1) 输入 INFO 命令,(2) 使用 --version 选项启动服务器,(3) 查看配置文件。

redis zset怎么使用 redis zset怎么使用 Apr 10, 2025 pm 07:27 PM

Redis 有序集合(ZSet)用于存储有序元素集合,并按关联分数进行排序。ZSet 的用法步骤包括:1. 创建 ZSet;2. 添加成员;3. 获取成员分数;4. 获取排名;5. 获取排名范围的成员;6. 删除成员;7. 获取元素个数;8. 获取分数范围内的成员个数。

redis查询的key怎么唯一 redis查询的key怎么唯一 Apr 10, 2025 pm 07:03 PM

Redis采用五种策略确保键的唯一性:1. 名称空间分隔;2. HASH数据结构;3. SET数据结构;4. 字符串键的特殊字符;5. Lua脚本验证。具体策略的选择取决于数据组织、性能和扩展性需求。

redis怎么查看所有的key redis怎么查看所有的key Apr 10, 2025 pm 07:15 PM

要查看 Redis 中的所有键,共有三种方法:使用 KEYS 命令返回所有匹配指定模式的键;使用 SCAN 命令迭代键并返回一组键;使用 INFO 命令获取键的总数。

See all articles