redis和平常写的数据结构有什么区别?
一、redis和平常写的数据结构的区别
最大的区别,redis 作为缓存组件,可以独立部署。这也是为什么本地内存很快,但还是要用 redis 这类缓存的原因。Redis是基于c语言编写的开源非关系型内存数据库,可以用作数据库、缓存、消息中间件。
redis是一个开源的使用C语言编写的一个kv存储系统,是一个速度非常快的非关系远程内存数据库。它支持包括String、List、Set、Zset、hash五种数据结构。除此之外,通过复制、持久化和客户端分片等特性,用户可以很方便地将redis扩展成一个能够包含数百GB数据和每秒处理上百万次的请求的系统。目前支持多种语言的api,方便用户使用。
redis同时也内置了事务、LUA脚本、复制等功能,提供两种持久化选项,一种是每隔一段时间将数据导入到磁盘(快照模式),另一种是追加命令到日志中(AOF模式)。如果只是作为高效的内存数据库使用也可以关闭持久化功能。通过哨兵(sentinel)和自动分区(Cuuster)的方式可以提高redis服务器的高可用性。
与关系型数据库相比,redis的命令请求不需要经过查询分析器或查询优化器进行处理,也避免了更新数据时引起的随机读\写,这些慢操作。它直接读写内存中的数据,并且数据是按照一定的数据结构存储的。所以它的速度非常快。
延伸阅读:
二、字符串(String)
与其它编程语言或其它键值存储提供的字符串非常相似,键(key)——值(value) (字符串格式),字符串拥有一些操作命令,如:get set del 还有一些比如自增或自减操作等等。redis是使用C语言开发,但C中并没有字符串类型,只能使用指针或符数组的形式表示一个字符串,所以redis设计了一种简单动态字符串(SDS[Simple Dynamic String])作为底实现:
定义SDS对象,此对象中包含三个属性:
len buf中已经占有的长度(表示此字符串的实际长度)
free buf中未使用的缓冲区长度
buf[] 实际保存字符串数据的地方
所以取字符串的长度的时间复杂度为O(1),另,buf[]中依然采用了C语言的以\0结尾可以直接使用C语言的部分标准C字符串库函数。
空间分配原则:当len小于IMB(1024*1024)时增加字符串分配空间大小为原来的2倍,当len大于等于1M时每次分配 额外多分配1M的空间。

相关推荐HOT
更多>>
没有内存泄漏,为什么还会OOM?
一、没有内存泄漏还会OOM的原因即使没有内存泄漏,也有可能出现OOM(Out of Memory)的情况,这通常是由于应用程序占用的内存超过了系统可用的...详情>>
2023-10-14 18:57:55
为什么redis小等于39字节的字符串是embstr编码,大于39是raw编码?
一、redis小于等于39字节的字符串是embstr编码,大于39是raw编码的原因Redis设计时考虑到了内存使用效率和CPU效率之间的平衡。因为Redis是一个...详情>>
2023-10-14 17:26:06
titaokr好用吗?
一、Titaokr的基本功能作为一款在线学习和考试平台,Titaokr为用户提供了一系列功能,包括课程管理、考试管理、学生管理、数据统计等。通过这些...详情>>
2023-10-14 16:19:17
二叉树、树、森林互相转换的意义是什么?
一、二叉树、树、森林互相转换的意义是什么二叉树、树、森林是数据结构中常见的一些形式,它们之间的转换意义在于可以方便地描述相应的问题,并...详情>>
2023-10-14 13:55:55