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

侯捷 C++ 课程学习笔记:C++内存管理机制

内存管理从平地到万丈高楼

内存管理入门(Memory Management 101)

需要具有动态分配并使用memory(存储(器),(计算机的)内存),使用过C++标准库的容器(containers)。

需要利用到的工具: Dev-C++ 5.11,with GUN 4.9.2(版本无所谓),Visual C++ 6.0

 网络有许多资源:Doug Lea’s Home Page(gee.cs.oswego.edu)

Doug Lea 自1986年起潜心研究malloc(内存分配器)算法,其作品被称为DL Malloc。目前Linux 的glibc 中的malloc 算法就是直接来自Doug Lea,其他平台的malloc 实现也或多或少受到DL 的影响,DL Malloc 源码可下载自Doug Lea 个人主页:Doug Lea's Workstation,内存分配器。

Bibliography (参考书目) :STL 源码剖析(作者:侯捷,Chap 2:allocator),Small Memory Software(作者:James Noble & Charles Weir,AW 2001),Modern C++ Design(作者:Andrei Alexadrescu,Chap 4:Small-Object Allocation,主要介绍loki)。

Libraries:STL Allocators,MFC CPlex+CFixedAlloc,Boost.Pool,Loki SmallObjAllocator,VC malloc/free,jemalloc,tcmalloc ┅。

Test-Mem.cpp 中有课程提到和所用的所有代码

primitives:原语;基本类型(在编程语境中,“primitives”常指基本数据类型,如整数、浮点数、布尔值等;也可表示基本操作或基本构件 )

malloc/free:“malloc”(动态内存分配函数,意为“内存分配” 内存分配器)/“free”(内存释放函数,意为“释放” )

std::allocator:标准分配器(“std”是 C++ 标准库命名空间 “standard” 的缩写,“allocator” 表示分配器,在 C++ 中用于管理内存分配和释放的机制 )

other allocators:其他分配器

loki::allocator:“Loki”(一种 C++ 库的名称 )::分配器

天宝当年,DOS 640K,and extented memory(以及扩展内存)。

内存分配的每一层面

C++ 应用程序

C++ Applications:绝大多数程序员所在层次,                                                                                 

C++ Library(std::allocator):最高阶使用C++标准库                                                                     

C++ primitives(new,new〔〕,new(),::operator new(),...)new〔〕:创建数组,基本工具   

CRT(malloc/free)最终到达的层面                                                                                       

O.S.API(such as HeapAlloc,VirtualAlloc,...)操作系统提供的内存的系统调用。太低阶,需要跟某一个操作系统绑死。这个就绕过了 malloc。 

四个层面的基本用法

C++ memory primitives

分配释放类别可否重载
malloc()free()C函数不可
newdeleteC++表达式(expressions)不可
::operator new()::operator delete()C++函数
allocator<T>::allocate()allocator<T>::deallocateC++标准库可自由设计并以之搭配任何容器

注:有不当之处,请批评指正!谢谢~

相关文章:

  • Qt 初识
  • Unity Android出包
  • Mysql高频面试题
  • Gemini 2.0 Flash
  • AQS及派生类
  • AI日报 - 2025年3月11日
  • Spring Cloud 负载均衡器架构选型
  • 什么是 MyBatis? 它的优点和缺点是什么?
  • [NewStarCTF 2023 公开赛道]ez_sql1 【sqlmap使用/大小写绕过】
  • 万字技术指南STM32F103C8T6 + ESP8266-01 连接 OneNet 平台 MQTT/HTTP
  • Hexo博客Icarus主题不蒜子 UV、PV 统计数据初始化配置
  • (done) MIT6.S081 Lec15 Crash recovery 学习笔记
  • tcp/ip协议配置参数有哪些?tcp/ip协议需要设置的参数有哪些
  • JAVA面试_进阶部分_深入理解socket网络异常
  • 每日一题----------String 和StringBuffer和StringBuiler重点
  • STM32步进电机驱动全解析(上) | 零基础入门STM32第五十七步
  • WLAN(无线局域网)安全
  • Java网络爬虫工程
  • Docker基础之运行原理
  • 【Redis】持久化(RDB和AOF)和事务
  • 商务部新闻发言人就美国企图全球禁用中国先进计算芯片发表谈话
  • 央行行长潘功胜主持召开金融支持实体经济座谈会
  • 上海乐高乐园客流预测来了:工作日0.8万人次/日,周末节假日2万人次/日
  • 讲述“外国货币上的中国故事”,《世界钱币上的中国印记》主题书刊出版发布
  • 俄乌直接谈判勉强收场,特朗普再次“电话外交”能否有用?|907编辑部
  • 海南保亭警方通报“两飞车党紧追女童”:两名初中生认错道歉