【Redis】——原理篇——数据结构

目录

一.底层数据结构

1.动态字符串

2.IntSet

3.Dict(字典)

4.ZipList

1.介绍

2.ziplist连锁更新问题

5.QuickList

6.SkipList(跳表)

6.RedisObject

二.五种数据结构

1.String

1.RAW编码方式

2.EMBSTR编码

3.INT编码

4.总结

2.List

3.Set(好友共同关注)

4.ZSet(排行榜)

5.Hash


一.底层数据结构

1.动态字符串

缺点

1.字符串长度需要做运算:需要遍历,需要运算

2.非二进制安全:\0表示结束,万一我们在数组中就有这个\0 导致出现问题

3.不可修改:"字面值"放在常量池中,无法修改

有\0也不会停止,知道字符串长度会读完为止。

动态扩容

2.IntSet

有序:是通过二分查找来完成的

**唯一:**做判断

3.Dict(字典)

当我们的元素越来越多,导致链表过长,怎么办?

rehash

4.ZipList

1.介绍

Dict会产生内存碎片,而且大量的指针会占用大量的内存。所以就引出ziplist。它是一片连续的内存空间,而且没有指针。

那么又没有指针,而且每个entry占的大小又不一样,它是如何找到每个entry的呢?

2.ziplist连锁更新问题

比如说现在出现了一个大于254字节的数据

每一个节点要记录前一个的字节大小,本来后一个本来是够的,结果不够了,就得不断的向后迁移,每一个后面的节点都得如此。

5.QuickList

6.SkipList(跳表)

ziplist和quicklist都是查头尾元素很快,但找中间的元素就很慢需要遍历。

skiplist有点像mysql中的索引,数据挂在索引下面。

6.RedisObject

二.五种数据结构

1.String

1.RAW编码方式

2.EMBSTR编码

3.INT编码

4.总结

2.List

首尾操作。

3.Set(好友共同关注)

4.ZSet(排行榜)

同时具备两种数据结构

功能很强大,太占用内存了。怎么办呢?

5.Hash

相关推荐
失散131 小时前
并发编程——17 CPU缓存架构详解&高性能内存队列Disruptor实战
java·缓存·架构·并发编程
郭俊强5 小时前
nestjs 缓存配置及防抖拦截器
缓存·nestjs·防抖
only-qi6 小时前
146. LRU 缓存
java·算法·缓存
酷ku的森10 小时前
Redis中的hash数据类型
数据库·redis·哈希算法
Arva .10 小时前
Redis
数据库·redis·缓存
博一波10 小时前
Redis 集群:连锁银行的 “多网点智能协作系统”
数据库·redis·缓存
tuokuac13 小时前
Redis 的相关文件作用
数据库·redis·缓存
cdcdhj15 小时前
数据库存储大量的json文件怎么样高效的读取和分页,利用文件缓存办法不占用内存
缓存·node.js·json
lingggggaaaa16 小时前
小迪安全v2023学习笔记(七十八讲)—— 数据库安全&Redis&CouchDB&H2database&未授权&CVE
redis·笔记·学习·算法·安全·网络安全·couchdb
得意霄尽欢16 小时前
Redis之核心数据结构浅析
数据结构·redis