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

【C++打怪之路Lv6】-- 内存管理

🌈 个人主页:白子寰
🔥 分类专栏:C++打怪之路,python从入门到精通,数据结构,C语言,C语言题集👈 希望得到您的订阅和支持~
💡 坚持创作博文(平均质量分82+),分享更多关于深度学习、C/C++,python领域的优质内容!(希望得到您的关注~)

目录

前言

C 或 C++ 为什么要有内存管理 

C/C++ 内存分布

C语言中动态内存管理方式

malloc

calloc

realloc

free

C++内存管理方式(与C语言对比)

前奏

new/delete 操作内置类型

new/delete 操作自定义类型

new 和 delete 的实现原理

​编辑

定位new表达式


前言

C 或 C++ 为什么要有内存管理 

C和C++需要内存管理的原因是

为了有效地控制动态内存分配与回收,防止内存泄漏和野指针,确保程序运行效率和稳定性




C/C++ 内存分布

C/C++将这些代码和变量等存在哪?

代码段存储可执行程序的代码和只读常量
数据段存储已初始化的全局变量和静态变量
用于程序运行时动态内存分配,从低地址向高地址增长
又叫堆栈,存储非静态局部变量/函数参数和返回值等,从高地址向低地址增长

那看看以下staticVar、localVal、char2、pChar3、ptr等存放在哪?

int globalVar = 1;				
static int staticGlobalVar = 1; 

int main()
{
	static int staticVar = 1;		
	int localVar = 1;				

	int num1[10] = { 1, 2, 3, 4 };	
	char char2[] = "abcd";			
	const char* pChar3 = "abcd";	
	int* ptr1 = (int*)malloc(sizeof(int) * 4); 
	int* ptr2 = (int*)calloc(4, sizeof(int));
	int* ptr3 = (int*)realloc(ptr2, sizeof(int) * 4);

	free(ptr1);
	free(ptr3);

	return 0;
}




C语言中动态内存管理方式

具体使用看该篇文章,这里简述保姆级教学 - C语言 之 动态内存管理

malloc

分配内存,开空间


calloc

开空间并初始化


realloc

对开空间的大小进行灵活调整


free

释放动态内存开辟的空间




C++内存管理方式(与C语言对比)

前奏

在学习C语言,我们是怎么开辟新空间和释放掉的?

虽说C++兼容C语言,那来到C++了,还是得升级一下的

那C++是如何申请和释放空间的呢?

new/delete 操作内置类型

小结

malloc 开空间

new     开空间并初始化   


new/delete 操作自定义类型




new 和 delete 的实现原理

new的原理(operator new)申请空间调用构造
delete的原理调用析构(operator delete)释放空间
new T[N]的原理(operator new[] ->(实际上是operator new))先申请空间,再调用N次构造
delete T[N]的原理先调用N次析构,再(operator delete[] ->(实际上是operator delete))释放空间



定位new表达式 

定位new表达式允许在已分配的内存上执行构造函数以初始化对象

通常,使用new操作符为对象动态分配内存。

为了优化性能,有时会采用内存池技术,通过malloc分配一大块内存。内存池减少了与堆的交次数,提高了内存分配效率

对于通过malloc分配的自定义类型内存必须使用定位new来手动调用构造函数

 




***********************************************************分割线*****************************************************************************
完结!!!
感谢浏览和阅读。

等等等等一下,分享最近喜欢的一句话:

“相信相信的力量,我就是我自己的神”。

我是白子寰,如果你喜欢我的作品,不妨你留个点赞+关注让我知道你曾来过。
你的点赞和关注是我持续写作的动力!!! 
好了划走吧。


http://www.kler.cn/news/333211.html

相关文章:

  • 【宽搜】4. leetcode 103 二叉树的锯齿形层序遍历
  • Python环境安装教程
  • 景区+商业,如何实现1+1>2?
  • 【ShuQiHere】深入理解 LC-3 的堆栈与基于中断的 I/O 机制
  • C/C++:内存管理
  • 遥感影像-语义分割数据集:云及云阴影数据集详细介绍及训练样本处理流程
  • CSS计数器
  • Effective C++中文版学习记录(二)
  • 【无人机设计与技术】自抗扰控制(ADRC)的建模与仿真研究
  • MongoDB 索引
  • 世优科技出席36氪2024具身智能大会圆桌对话,入选创新应用案例
  • SOMEIP_ETS_166: SD_TestFieldUINT8
  • 【MySQL】数据库中的内置函数
  • 《程序猿之Redis缓存实战 · 有序集合类型》
  • XSLT 实例:掌握 XML 转换的艺术
  • 22.3 解读k8s服务发现源码
  • Vite+Vue3+SpringBoot项目如何打包部署
  • shadcn-vue 快速入门(2)
  • LLaMA 3 和 OpenAI有哪些相同点和不同点?
  • 昇思学习打卡营第32天|基于ResNet50的中药炮制饮片质量判断模型