当前位置: 首页 > news >正文

Redis为什么这么快?

1.基于内存存储实现

在MySQL数据库中,所有的读写操作都要通过IO的方式从硬盘中获取。在Redis中,所有的操作都是基于内存实现的,从而减少IO操作提高数据库性能。

2.高效的数据结构

SAS简单动态字符串

  • 字符串长度:SAS查询的时间复杂度O(1),c语言中时间复杂度O(n)
  • 空间分配来看:
    • 在c语言中,频繁的修改字符串,会频繁的修改空间大小很耗费性能。
    • SAS如果修改字符串,只需调用未分配的空间即可。
  • 惰性空间的释放:SAS在缩短时,不是去分配空间。而是通过free指针记录释放的空间,省的去操作空间。以此节约时间。
  • 二进制存储:Redis可以存储二进制数据,而c语言遇到’/0’结束。而SAS时根据len属性来判断是否结束。

字典

字典实际上就是哈希表,在redis中大部分数据存储都使用到了哈希表的结构。在java中的hashMap也使用字典数据结构。好处就是获取任意值的时间复杂度为O(1)

跳跃表

  • 是Redis特有的数据结构,是在链表的基础上,增加了多级索引来增强查找效率问题。
  • 跳跃表的平均查找的时间复杂O(logn),最坏查找O(n)

3.合理的编码方式

  • String :
    • 当值为数字时,编码格式int。
    • 当值为字符串时且长度小于等于39时,编码格式为embstr
    • 当值为字符串且长度大于39时ÿ
http://www.lryc.cn/news/1409.html

相关文章:

  • 几种实现主题切换的方式
  • Jenkins使用(代码拉取->编译构建->部署上线)
  • IEEE期刊论文投稿前期准备
  • [AAAI 2022] TransFG: A Transformer Architecture for Fine-grained Recognition
  • 机器学习之决策树原理详解、公式推导(手推)、面试问题、简单实例(python实现,sklearn调包)
  • 一文搞懂CAS实现原理——怀玉
  • typora每次复制文档都要附带图片文件夹?学会配置gitee图床
  • Linux--gdb
  • c++11 标准模板(STL)(std::multimap)(二)
  • 【数据结构】二叉排序树——平衡二叉树的调整
  • 03- pandas 数据库可视化 (数据库)
  • 第三方电容笔怎么样?开学适合买的电容笔
  • Java学习-IO流-字节输出流
  • linux性能分析 性能之巅学习笔记和内容摘录
  • 机器学习笔记之生成模型综述(三)生成模型的表示、推断、学习任务
  • 第八章 Flink集成Iceberg的DataStreamAPI、TableSQLAPI详解
  • PyTorch学习笔记:nn.Sigmoid——Sigmoid激活函数
  • 个人学习系列 - 解决拦截器操作请求参数后台无法获取
  • 【编程基础之Python】2、安装Python环境
  • Java开发 - 问君能有几多愁,Spring Boot瞅一瞅。
  • Office Server Document Converter Lib SDK Crack
  • Cubox是什么应用?如何将Cubox同步至Notion、语雀、在线文档中
  • 计算机网络-传输层
  • HTML-CSS-js教程
  • 【Nacos】Nacos配置中心客户端启动源码分析
  • 中国特色地流程管理系统,天翎让流程审批更简单
  • Python算法:DFS排列与组合算法(手写模板)
  • 拿来就用的Java海报生成器ImageCombiner(一)
  • 【C++】类和对象(二)
  • UDP协议