侯捷 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函数 | 不可 |
| new | delete | C++表达式(expressions) | 不可 |
| ::operator new() | ::operator delete() | C++函数 | 可 |
| allocator<T>::allocate() | allocator<T>::deallocate | C++标准库 | 可自由设计并以之搭配任何容器 |
注:有不当之处,请批评指正!谢谢~
相关文章:
侯捷 C++ 课程学习笔记:C++内存管理机制
内存管理从平地到万丈高楼 内存管理入门(Memory Management 101) 需要具有动态分配并使用memory(存储(器),(计算机的)内存),使用过C标准库的容器࿰…...
JVM常用概念之本地内存跟踪
问题 Java应用启动或者运行过程中报“内存不足!”,我们该怎么办? 基础知识 对于一个在本地机器运行的JVM应用而言,需要足够的内存来存储机器代码、堆元数据、类元数据、内存分析等数据结构,来保证JVM应用的成功启动以及未来平…...
【鸿蒙开发】Hi3861学习笔记- 软件定时器示例
00. 目录 文章目录 00. 目录01. 定时器概述02. 定时器API03. 定时器常用API3.1 osTimerNew3.2 osTimerDelete3.3 osTimerStart3.4 osTimerStop 04. 程序示例05. 附录 01. 定时器概述 软件定时器,是基于系统Tick时钟中断且由软件来模拟的定时器,当经过设…...
在Html5中仿Matlab自定义色带生成实践
目录 前言 一、RGB的相关知识 1、RGB的基本原理 2、RGB的数值表示 3、应用场景 二、ColorMap生成实战 1、外部库介绍 2、相关API 3、实例生成 三、总结 前言 在现代网页开发与数据可视化领域,色彩的表现力对于信息传达和视觉体验起着至关重要的作用。色带&…...
贪心算法--
1.柠檬水找零 link:860. 柠檬水找零 - 力扣(LeetCode) code class Solution { public:bool lemonadeChange(vector<int>& bills) {// 贪心算法, 优先花出大面额bill, 尽可能保护小面额billint five 0, ten 0;// 不…...
【学习方法一】
学习方法一 一、通用高效学习法二、学科专项方法三、工具与技术辅助四、习惯与心理策略五、避免常见误区总结六、进阶学习策略七、解决学习痛点八、场景化学习法九、资源与工具推荐十、个性化学习调整十一、长期学习心态十二、常见问题QA十三、应对特殊挑战的学习法十四、健康与…...
k8s启动时calico-kube-controllers与coredns组件一直是pending状态
症状: k8s执行kubectl get po -n kube-system时,以下组件一直>是pending状态: calico-kube-controllerscoredns 当执行 kubectl get po -n kube-system 发现 calico-kube-controllers 和 coredns 一直处于 Pending 状态时,通常…...
ngx_openssl_create_conf
ngx_openssl_create_conf 声明在 src\event\ngx_event_openssl.c static void *ngx_openssl_create_conf(ngx_cycle_t *cycle); 定义在 src\event\ngx_event_openssl.c static void * ngx_openssl_create_conf(ngx_cycle_t *cycle) {ngx_openssl_conf_t *oscf;oscf ngx_…...
如何选择国产串口屏?
目录 1、迪文 2、淘晶驰 3、广州大彩 4、金玺智控 5、欣瑞达 6、富莱新 7、冠显 8、有彩 串口屏,顾名思义,就是通过串口通信接口(如RS232、RS485、TTL UART等)与主控设备进行通信的显示屏。其核心功能是显示信息和接收输入…...
matlab慕课学习3.1
3.1顺序结构程序 于20250306 3.1.1程序和程序设计 程序是用某种计算机能够理解并且能够执行的语言来描述的解决问题的方法和步骤。 3.1.2程序的三种基本结构 1.顺序结构 2.选择结构 3.循环结构 3.1.3脚本文件和函数文件 脚本文件是可在命令行窗口直接执行的文件࿰…...
EB-Cable许可管理系统的功能和特点
在数字化时代,软件许可管理已成为企业日常运营中不可或缺的一部分。EB-Cable许可管理系统作为一款专为电缆管理而设计的软件解决方案,为企业提供了全面、高效且灵活的许可管理功能。本文将详细介绍EB-Cable许可管理系统的功能和特点,帮助您快…...
cesium地图设置3d,2d,2.5d动态切换
通过修改cesium实例vw的scene的显示模式,来切换最终的显示模式。 Cesium.SceneMode总共有四个变量值,分别如下:NameTypeDescriptionMORPHINGnumber在3d与2d之间切换变体 between mode, e.g., 3D to 2D.COLUMBUS_VIEWnumber2.5d模式࿰…...
Mac如何查看 IDEA 的日志文件
在 macOS 上,IntelliJ IDEA 的日志文件通常存储在用户目录下的 .IntelliJIdea<版本号> 文件夹中。以下是查看日志文件的具体步骤: 1. 找到日志文件的位置 日志文件通常位于以下路径: ~/Library/Logs/IntelliJIdea<版本号> 其…...
linux 软件安装(下)
七、ElasticSearch安装 官网地址:Elasticsearch:官方分布式搜索和分析引擎 | Elastic 官网下载地址:Past Releases of Elastic Stack Software | Elastic 7.1、linux安装 1、上传安装包 altp # 打开sftp窗口 # 上传es安装包 put e:/sof…...
MongoDB 自动化部署
部署在容器中,并且自动创建所需用户和权限等 # 启动 mongoDBsudo docker run -dit --name china_fish_mongo \ -p 27017:27017 \ -v /data/project1/db/mongo/config/mongod.conf:/etc/mongod.conf \ -v /data/project1/db/mongo/data:/data/db \ -v /data/project1…...
程序化广告知识入门与Python基础数据处理实践
程序化广告知识入门与Python基础数据处理实践 大家好!我写这一系列博客的初衷是想和大家一起学习进步。在技术飞速发展的今天,数据处理能力愈发重要,Python作为强大的数据处理工具,掌握它能为我们的职业发展和技术提升带来极大帮…...
【数据结构】二叉搜索树、平衡搜索树、红黑树
二叉搜索树(Binary Search Tree) 二叉搜索树是一种特殊的二叉树,它用来快速搜索某个值,对于每个节点都应该满足以下条件: 若该节点有左子树,那么左子树中所有节点的值都应该小于该节点的值。若该节点有右…...
密码学(终极版)
加密 & 解密 备注:密码学领域不存在完全不能破解的密码,但是如果一个密码需要很久很久,例如一万年才能破解,就认为这个密码是安全的了。 对称加密 非对称加密 公钥加密、私钥解密 私钥签名、公钥认证 非对称的底层原理是…...
经销商管理系统选型解析:8款产品详评
本文主要介绍了以下8款经销商管理系统:1.纷享销客; 2.用友T6经销商管理系统; 3.金蝶经销商管理系统; 4.鼎捷经销商管理系统; 5.浪潮经销商管理系统; 6.销售易; 7.SAP Business One Distributor …...
Go 语言封装 HTTP 请求的 Curl 工具包
文章目录 Go 语言封装 HTTP 请求的 Curl 工具包🏗️ 工具包结构简介核心结构体定义初始化函数 🌟 功能实现1. 设置请求头2. 构建请求3. 发送请求4. 发送 GET 请求5. 发送 POST 请求6. 发送 PUT 请求7. 发送 DELETE 请求8. 读取响应体 💡 实现…...
【C++】函数重载与nullptr
1、函数重载 C支持在同一个作用域中出现同名函数,但是要求这些同名函数的形参不同,可以是形参个数不同或者类型不同。这样C函数调用就表现出了多态行为,使用更灵活。C语言是不支持同一作用域中出现同名函数的。 代码: 形参类型不…...
全球首款 5G-A 人形机器人发布
全球首款 5G-A 人形机器人于世界移动通信大会(MWC2025)上由中国移动、华为、乐聚联合发布。以下是关于这款机器人的详细介绍: 名称与背景 名称9:这款人形机器人名为 “夸父”,是中国移动、华为与乐聚机器人在 GTI 平台…...
第5节:交换技术与VLAN技术
交换机工作原理与VLAN技术实战 在现代网络中,交换机是构建局域网(LAN)的核心设备,而VLAN(虚拟局域网)技术则是优化网络管理和性能的关键工具。本文将以华为三层交换机为例,深入探讨交换机的工作原理、VLAN的配置与Trunk技术,以及STP(生成树协议)的应用,帮助读者全面…...
程序化广告行业(2/89):从程序化广告深挖数据处理技巧
程序化广告行业(2/89):从程序化广告深挖数据处理技巧 大家好!我一直希望能和大家在技术学习的道路上携手共进,这也是我写这一系列博客的初衷。上次我们一起学习了Python基础的数据处理知识,这次咱们借助一…...
【10】单片机时间和速度的起源:指令周期与晶振频率
【10】单片机时间和速度的起源:指令周期与晶振频率 🌟 核心概念 单片机的运算速度与时间控制,本质上由 指令周期 和 晶振频率 共同决定。理解这两者的关系,是掌握单片机底层控制的关键。 📌 1. 节拍与指令周期 &…...
处理动态分页:自动翻页与增量数据抓取策略-数据议事厅
一、案例场景 Lily(挥舞着数据报表):“用户反馈我们的股票舆情分析总是缺失最新跟帖!这些动态分页像狡猾的狐狸,每次抓取都漏掉关键数据!” 小王(调试着爬虫代码):“传…...
用android studio模拟器,模拟安卓手机访问网页,使用Chrome 开发者工具查看控制台信息
web 网页项目在安卓手机打开时出现问题,想要查看控制台调试信息。记录一下使用android studio 模拟器访问的方式。 步骤如下: 1.安装android studio,新增虚拟设备(VDM- virtual device manager) 点击Virtual Device Manager后会…...
动态规划中固定倒数第二个数与倒数第一个数的区别与应用场景分析 —— 从最长等差数列问题到统计等差数列个数的填表策略对比
目录 1. 问题目标的区别 (1)找到最长的等差数列 (2)统计等差数列的个数 2. 填表顺序的区别 (1)固定倒数第二个数(i) (2)固定倒数第一个数(j&…...
【C语言】数组篇
目录 引言一维数组数组的定义数组的初始化完全初始化部分初始化省略数组长度 数组元素的访问 多维数组二维数组的定义二维数组的初始化完全初始化部分初始化省略第一维长度 二维数组元素的访问 遍历数组元素遍历一维数组遍历二维数组 数组作为函数参数一维数组作为函数参数二维…...
【Linux内核系列】:深入理解缓冲区
🔥 本文专栏:Linux 🌸作者主页:努力努力再努力wz ★★★ 本文前置知识: 文件系统以及相关系统调用接口 输入以及输出重定向 那么在此前的学习中,我们了解了文件的概念以及相关的系统调用接口,并…...
