高并发内存池——单例模式在缓存的作用

单例模式

单例模式是一种创建型设计模式,旨在确保一个类只有一个实例,并提供一个全局访问点来访问该实例。这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个对象被创建。++适用于需要全局统一管理、避免重复创建实例资源的情况下++。


单例模式在中心缓存的核心作用

前提:CentralCache(中心缓存)是内存池的核心枢纽,上连PageCache(页缓存),下接ThreadCache(线程缓存),负责统一管理内存Span(内存块)的分配、回收、合并等,是整个内存分配体系的核心。

而单例模式的作用是确保了CentralCache的某些特性。


我们可以根据中心缓存的需求来理解单例模式的作用:

1.CentralCache的核心责任是统一管控所有线程的内存申请与释放,我们需要保证的是其内存管理的全局唯一性!

如果其不是单例的,而是每个线程都有一个中心缓存,就会出现多种问题,比如出现多个CentralCache各自向PageCache申请内存,进而导致严重的内存碎片化。

2.避免多个实例导致的资源竞争与数据不一致的问题

中心缓存内部维护着不同大小的Span链表,这些链表是全局共享的临界资源。如果非单例模式下,需要对每个线程的CentralCache加锁,而单例模式下只需要对全局唯一的CentralCache的Span链表进行加锁保护,大大降低了难度。

3.简化内存池的设计与使用

实例的创建本身存在着天然的复杂性(实例创建存在则构造、拷贝、销毁等等多个实例的情况),这可能导致CentralCache将不再唯一,而单例模式则帮助避免了这些情况,并且只需要对内存、锁、链表等资源初始化一次,避免多实例重复占用资源。


由此我们得出了单例模式对中心缓存的核心作用为:

1.保证了唯一性,确保全局只有一个内存调度枢纽,实现内存的统一调用。

2.保证了一致性,避免多实例导致的数据混乱、资源竞争等问题,并且简化了临界资源的锁保护问题。

3.简化了中心缓存,使代码难度降低,降低了实例创建等的设计复杂性。

总结:单例模式强制整个程序只有一个CentralCache实例,确保所有线程的内存流转都经过同一个 "枢纽",实现内存的全局统一调度。

相关推荐
jeCA EURG3 小时前
一、安装Redis(win11环境下)
数据库·redis·缓存
AILabNotes3 小时前
016、性能与安全权衡:网关的缓存、中继与匿名化策略
安全·缓存
小江的记录本6 小时前
【分布式】分布式核心组件——分布式ID生成:雪花算法、号段模式、美团Leaf、百度UidGenerator、时钟回拨解决方案
分布式·后端·算法·缓存·性能优化·架构·系统架构
晔子yy7 小时前
【JAVA探索之路】从头开始讲透、实现单例模式
java·开发语言·单例模式
摇滚侠21 小时前
短信验证码登录 Redis实战 黑马程序员
数据库·redis·缓存
014-code1 天前
Redis Stream:消息队列的进阶之路
数据库·redis·缓存
IntMainJhy1 天前
【Flutter for OpenHarmony 】第三方库 实战:`cached_network_image` 图片缓存+骨架屏鸿蒙适配全指南✨
flutter·缓存·harmonyos
JoshRen1 天前
Window下Redis的安装和部署详细图文教程(Redis的安装和可视化工具的使用)
数据库·redis·缓存
eRRA OFAG1 天前
Redis 设置密码无效问题解决
数据库·redis·缓存