Redis数据结构

Redis 共有 5 种基本数据类型:

String(字符串)、List(列表)、Set(集合)、Hash(散列)、Zset(有序集合)。

String

key : String类型的value

String的底层实现是基于C语言实现的SDS结构体简单动态字符串(Simple Dynamic String))

Redis的SDS通过

buf\[\]保存数据

len获取字符串长度(复杂度为 O(1)(C 字符串为 O(N)

alloc 记录已分配的空间(初始时等于len,扩容之后会大于len)

List

Redis 实现了自己的链表数据结构。Redis 的 List 的实现为一个 双向链表

应用场景

消息队列:功能过于简单

Hash

Redis 中的 Hash 是一个 String 类型的 field-value(键值对) 的映射表,特别适合用于存储对象,后续操作的时候,你可以直接修改这个对象中的某些字段的值。

Hash 类似于 JDK1.8 前的 HashMap,内部实现也差不多(数组 + 链表)

应用场景:

实现简单分布式锁,可以用Hash类型,key : {threaId:12, count:1}, count可实现可重入锁

Set

Redis 中的 Set 类型是一种无序集合,集合中的元素没有先后顺序但都唯一,有点类似于 Java 中的 HashSet 。并且 Set 提供了判断某个元素是否在一个 Set 集合内的重要接口

应用场景:

1、防止超卖(已经买过的用户id被存放在set中),文章点赞(点过赞的用户不能重复点赞)

2、共同好友(两个用户的好友set 取交集)

3、抽奖(SPOP命令,随机获取集合中的元素并移除,适合不允许重复中奖的场景)

Sorted Set

Sorted Set 类似于 Set,但和 Set 相比,Sorted Set 增加了一个权重参数 score,使得集合中的元素能够按 score 进行有序排列,还可以通过 score 的范围来获取元素的列表。有点像是 Java 中 HashMapTreeSet 的结合体。

应用场景

需要随机获取数据源中的元素根据某个权重进行排序的场景

相关推荐
方也_arkling5 小时前
【Java-Day08】static / final / 枚举
java·开发语言
橙淮5 小时前
Spring Bean作用域与生命周期全解析
java·spring
Chengbei116 小时前
一站式源码安全检测工具、云安全 / APP / 小程序源码敏感信息递归多层目录扫描AK、JWT、手机号、身份证等敏感信息
java·开发语言·安全·web安全·网络安全·系统安全·安全架构
llz_1126 小时前
web-第一次课后作业
java·开发语言·idea
kkeeper~6 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
秋96 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本6 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
2401_868534786 小时前
论企业网络设计
数据结构
cfm_29146 小时前
Redis数据安全性解析
数据库·redis·缓存
DIY源码阁6 小时前
JavaSwing学生成绩管理系统 - MySQL版
java·数据库·mysql·eclipse