Linux 下 C 语言 栈 堆的学习
C程序有两个存储区,一个是静态存储区,一个是动态存储区
静态存储区用来存放代码段,全局变量
动态存储区又分为栈和堆
栈是用来存放局部变量的,而堆是用来动态申请内存的,我们经常用的malloc 就是在堆里申请内存,返回申请的这块区域的首地址,
我们对动态存储区的操作会多于静态存储区,因为动态存储区是我们运行程序是才有的区域,在程序结束的时候,这块区域会被收回。
对于栈这个概念我觉得应该知道栈的后进先出的存储方式,栈是线性连续存储的,而且是由高地址向低地址增长的,而堆却是恰恰相反,堆并没有栈那么井井有条,他是链式存储的,有点类似二叉树的感觉,可以随意的进出,并不像栈那样拘束,但是总体上看,堆是低地址向高地址增长的,也就是向上增长。栈数据在生命周期上看,栈上的数据往往是短命的,当程序运行时,进入main函数,在动态存储区里就会产生一个栈帧,姑且叫他M栈帧,这个栈帧是在这些短命鬼里最长寿的,当在main函数调用一个方法(函数)是,就会产生一个栈帧(每个函数都会有与之对应的栈帧,存储着局部变量,参数等),姑且叫他短命鬼栈帧,这个栈帧会随着函数的出生而出生,也会随着函数的死亡而死亡,当他死亡的时候,当他死亡的时候,栈帧里面的数据就自然没有了,堆就不同的,malloc是专门在堆里面开辟空间的,当开辟的一段空间后,这段空间不会随着函数的变化而变化,只有调用销毁函数(free),他才会消失;