目录
前言
1.结合地址空间来理解不同对象的存储区域
2.malloc和free以及new和delete的区别
3.什么是内存泄漏?
前言
对于一个程序来说,我们必须知道他的各个位置的变量存放在哪里的,所以我们必须要清楚C++的内存分布。其实内存管理是衡量一个人代码逻辑的重要指标,一旦你掌握了内存,那么程序的运行逻辑在你的眼里就是透明的。下面通过看图和理解两个问题就能理解内存管理。
1.结合地址空间来理解不同对象的存储区域
我们学习语法的时候,学的都是粗粒度划分的内存分区,也就是我们常说的内核区、栈区、映射区、堆区、静态区(数据段全局和静态)、常量区(代码和只读常量)。如左图。
但是我们学习操作系统的时候,我们知道程序也就是进程在OS上运行的时候,都是在虚拟地址空间上进行的,方便解耦底层的磁盘存储区域。我们就可以细分一下如右图。
细粒度划分就会是内核区,命令行参数和环境变量区,栈区,共享区,堆区,已初始化全局数据 ,未初始化全局数据,只读字符常量区,代码区。
2.malloc和free以及new和delete的区别
malloc和free是我们C语言进场接触到的内存申请方式,但是不方便申请,我们还需要自己对内存的大小进行计算,C++在这个基础上对malloc进行了改进,根据类型自动计算大小,底层原理是调用构造函数。
回答:①new和delete是操作符,malloc和free是库函数,用法上new直接跟类型加申请的个数,malloc是需要计算自己申请了多大的个数,且需要强转一下void*因为他只负责开空间。
②new返回的是对应类型的指针,不需要强转,new就是构造函数加初始化,new失败了抛异常,malloc是返回空指针。
3.什么是内存泄漏,如何预防?
关于内存泄漏,他的本质就是指针丢了,我们指向的内存对象并没有释放,内存依然处于被使用,无法重用和析构。
比如:进程僵尸,长期运行在程序在堆上申请的内存空间没有释放,对应堆内存泄漏和系统资源泄漏。
回答:主要两个方面①事先预防:严谨的设计思维RAII②使用智能指针。③事后补救,内存检查工具。