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

STL之空间配置器

1. 什么是空间配置器

空间配置器,顾名思义就是为各个容器高效的管理空间(空间的申请与回收)的,在默默地工作。虽然在常规使用STL时,可能用不到它,但站在学习研究的角度,学习它的实现原理对我们有很大的帮助。

image-20221018105333972

2. 为什么需要空间配置器

前面在模拟实现vector、list、map、unordered_map等容器时,所有需要空间的地方都是通过 new申请的,虽然代码可以正常运行,但是有以下不足之处:

  • 空间申请与释放需要用户自己管理,容易造成内存泄漏
  • 频繁向系统申请小块内存块,容易造成内存碎片
  • 频繁向系统申请小块内存,影响程序运行效率
  • 直接使用malloc与new进行申请,每块空间前有额外空间浪费(额外的空间是用来记录空间大小的,方便delete和free)
  • 申请空间失败怎么应对
  • 代码结构比较混乱,代码复用率不高
  • 未考虑线程安全问题

因此需要设计一块高效的内存管理机制。

3. SGI-STL空间配置器实现原理

实现原理

SGI-STL以128作为小块内存与大块内存的分界线,将空间配置器其分为两级结构,一级空间配置器处理大块内存,二级空间配置器处理小块内存

image-20221018145731231

image-20221018113506582

image-20221018140526219

问:那么这些桶是怎么链接的呢?

答:通过下图中的方式进行链接:

image-20221018140936463

上面的这种方式也体现了8字节对齐的原因。

容器中是如何使用空间配置器的(以list容器为例)

image-20221018161727649

空间配置器的好处

  • 频繁申请小块内存效率高
  • 一定程度上减少内存碎片

了解内存碎片

外碎片

问题描述:有足够内存,但是不连续,无法申请大块内存。

产生原因:频繁向系统申请小块内存导致的。

image-20221018150253052

内碎片

问题描述:内存块挂起来管理,按一定规则对齐,就会导致内碎片。

产生原因:内存对齐,多给内存。

image-20221018150838921

内碎片在内存池中是广泛存在的问题。

相关文章:

  • 【深度学习与实战】2.1、线性回归模型与梯度下降法先导
  • 数据结构:利用递推式计算next表
  • PostgreSQL详解
  • SiLU与GeLU激活函数:现代大模型的选择
  • WindowsPowerShell、CMD Linux Bash对比分析
  • 工作中遇到的spark SQL小问题:包含某个或某些字符的条件
  • uniapp + Axios + 小程序封装网络请求
  • 力扣HOT100之子串:76. 最小覆盖子串
  • mock.js模拟数据
  • 在linux部署网站
  • Rust vs. Go: 在仅使用标准库时的性能测试
  • 数据库基础知识点(系列七)
  • element-plus 的简单应用
  • Python----计算机视觉处理(Opencv:图像边缘检测:非极大值抑制,双阈值筛选)
  • Vue基本使用
  • qt+opengl 加载三维obj文件
  • 23.linux下电脑健康检查
  • 【NLP 47、实践 ⑫ 通过mask和loss计算实现SFT】
  • TensorRT怎么实现加速的
  • 001初识多视图几何
  • 文旅部:加强对景区索道、游船等设施设备安全隐患排查整治
  • 中标多家学校采购项目的App查成绩需付费?涉事公司回应
  • 共生与伴生:关于人工智能时代艺术评论的对象与主体的思考
  • 公安部:“五一”假期全国社会大局稳定,治安秩序良好
  • 铁路五一假期运输旅客发送量累计超1亿人次,今日预计发送2110万人次
  • 贵州黔西游船倾覆事故70名落水人员在院救治,均为轻伤