redis对应的数据类型及其底层实现原理

知识浅谈 🐄🐄🐄🐄🐄大佬
后端领域优质创作者
博客专家认证
2022-09-09 13:55:04

redis对应的数据类型

  1. String
  2. List
  3. Hash
  4. Set
  5. Zset

底层原理

String :在C语言中如果是数字小于2^64-1 使用int存储,其它字符串在redis新版本上如果小于44字节,是哦也能够embstr(压缩字符串),否则使用raw,两者都是基于sds(简单动态字符串结构)实现,区别就是sds object和数据是分开的。
List:当列表个数小于512且单个元素小于64字节,使用压缩列表ziplist,否则使用双向循环列表
Hash:当列表个数小于512且单个元素小于64字节,使用压缩列表ziplist,否则使用散列表
Set:存储的数据是整数,且不超过512个,使用有序数组存储,否则使用散列表
Zset:当列表个数小于512且单个元素小于64字节,使用压缩列表ziplist,否则使用跳表,zset排序是每个元素对应一个score值,按照这个值排序的。

...全文
7 回复 打赏 收藏 举报
写回复
回复
切换为时间正序
请发表友善的回复…
发表回复
相关推荐
发帖
知识浅谈后端社区

1839

社区成员

知识浅谈(带你学后端)社区,旨在为学习后端的小伙伴提供技术内容共享学习平台,助力每位小伙伴写出高质量代码,欢迎各位小伙伴的加入。
java爬虫后端 个人社区 吉林省·长春市
社区管理员
  • 知识浅谈
加入社区
帖子事件
创建了帖子
2022-09-09 13:55
社区公告

【社区倡导与禁止】

  • 社区倡导积极发帖,互相交流技术问题,学习心得。
  • 社区不限制技术领域,后端内容增加加精权重
  • 社区禁止发布低俗、不健康的内容

【社区积分规则】

  • 在社区「发帖」得10积分
  • 内容被管理员「加精」得10积分
  • 点赞他人内容得1积分
  • 评论内容得2积分