C语言程序中的栈、堆、静态存储区
栈
栈是现代计算机程序里最为重要的概念之一
栈在程序中用于维护函数调用上下文,没有栈就没有函数,没有局部变量
程序中的栈
栈保存了一个函数调用所需的维护信息
*函数参数,函数返回地址
* 局部变量
* 函数调用上下文
程序中的堆
为什么有了栈还需要堆?
*栈上的数据在函数返回后就会被释放掉,无法传递到函数外部,如:局部数组
堆是程序中一块巨大的内存空间,可由程序自由使用
堆中被程序申请使用的内存在程序主动释放前将一直有效
堆空间通过申请才能获得!
系统对堆空间的管理方式
空闲链表法,位图法,对象池法等等
如图为空闲链表法管理示意图,理解了空闲链表法管理,也就可以理解上篇文章讲到的动态申请内存,实际返回的可能比申请的要多一些。感兴趣的可以去看看深入理解计算机系统。
程序中的静态存储区
程序静态存储区随着程序的运行而分配空间,直到程序运行结束
在程序的编译期静态存储区的大小就已经确定
程序的静态存储区主要用于保存程序中的全局变量和静态变量
与栈和堆不同,静态存储区的信息最终会保存到可执行程序中
小结
栈,堆和静态存储区是C语言程序常涉及的三个基本内存区
栈区主要用于函数调用的使用
堆区主要是用于内存的动态申请和归还
静态存储区用于保存全局变量和静态变量