一、概念区分
在进程地址布局(如下图),可见地址的分布情况,栈和堆所在的位置区域。
栈:由编译器自动分配释放,存放函数的参数值、局部变量的值等。其操作方式类似于数据结构中的栈。每当一个函数被调用,该函数返回地址和一些关于调用的信息,比如某些寄存器的内容,被存储到栈区。然后这个被调用的函数再为它的自动变量和临时变量在栈区上分配空间,这就是C实现函数递归调用的方法。每执行一次递归函数调用,一个新的栈框架就会被使用,这样这个新实例栈里的变量就不会和该函数的另一个实例栈里面的变量混淆。用于维护函数调用的上下文,离开了栈函数调用就没法实现。栈通常在用户空间的最高地址分配,通常有数兆字节大小。
堆:是用来容纳应用程序动态分布的内存区域,当程序使用malloc或new分配内存时,得到的内存来自堆里,一般由程序员分配和释放,若程序员不释放,程序结束时有可能由OS回收。堆通常在栈的下方(低地址方向),在某些时候,堆一般比栈大很多,可以有几十至数百兆字节的容量。

78
\;Linux进程地址空间布局
如下图,这是一个栈的实例这里的栈底指针是0xbfffffff,而esp寄存器标明了栈顶,地址为0xbffffff4。在栈上压入数据会导致esp减少,弹出数据使得esp增大。相反,直接减少es