一般来说,我们可以简单的理解为内存分为三个部分:静态区,栈,堆。很多书没有把把堆和栈解释清楚,导致初学者总是分不清楚。其实堆栈就是栈,而不是堆。堆的英文是heap ;栈的英文是stack,也翻译为堆栈。堆和栈都有自己的特性。
程序中的栈
栈是现代计算机程序里最重要的概念之一
栈在程序中用于维护函数调用的上下文,没有栈就没有函数,没有局部变量
后进先出
栈保存了一个函数调用所需的维护信息:
.函数参数,函数返回地址
.局部变量
.函数调用上下文
活动记录在栈上建立,当函数运行结束,这些内容也会自动被销毁。其特点是效率高,但空间大小有限。
没有栈就没有函数,所以栈是现代计算机程序里最重要的概念之一,栈的存在是为了函数的存在而存在的
为什么不要返回一个局部变量的指针?当函数调用只后,栈顶指针esp回退,释放掉这片空间,局部变量就被释放了,会被下一个函数调用所占用到,下一个函数就很可能把原来内存空间的值改变
程序中的堆
为什么有了栈还需要堆?
.栈上的数据在函数返回后就会被释放掉,无法传递到函数外部,如:不可以传递一个局部数组回去
堆是程序中一块巨大的内存空间,可由程序自由使用
堆中被程序申请使用的内存在程序主动释放前将一直有效
堆由malloc 系列函数或new 操作符分配。其生命周期由free 或delete 决定。在没有释放之前一直存在,直到程序结束。其特点是使用灵活,空间比较大,但容易出错。
系统对堆空间的管理方式
.空闲链表法,位图发,对象池法等等
程序中的静态存储区
程序静态存储区随着程序的运行而分配的空间,直到程序运行结束
程序的静态存储区主要用于保存程序中的全局变量和静态变量(包括static全局和局部变量)
与栈和堆不同,静态存储区的信息最终会保存到可执行程序中
小结:
栈区主要用于函数调用的使用
堆区主要用于内存的动态申请和归还
静态区主要用于保存全局变量和静态变量