有一点汇编经验的朋友应该知道 push eax的时候, 会先进行esp = esp -4, 然后在把 eax内存入栈. 每push一次 esp就会减少.也就是说栈地址 是往低处生长的.
那么为什么会这样呢?
这可能因为: 堆往高处走, 栈只好委屈一下往"低处流"!
话不多说, 直接上代码, 看的明白!
在VS2019 X86模式下Debug, 不进行任何编译器优化, 运行如下代码:
#include <iostream>
using namespace std;
/*
*三个函数内容是一样的: 一个栈变量s, 一个堆变量h
*分别打印出栈变量和堆变量的地址
*func1 调用 func2 , func2 调用 func3
*/
void func3()
{
int s[64];
int* h = new int[64];
std::cout << "func3:" << endl;
std::cout << "in stack:" << endl;
std::cout << "addr s:" << s << endl;
std::cout << "in heap:" << endl;
std::cout << "addr h:" << h << endl;
std::cout << endl;
}
void func2()
{
int s[64];
int* h = new int[64];
std::cout << "func2:" << endl;
std::cout << "in stack:"<< endl;
std::cout << "addr s:" << s << endl;
std::cout << "in heap:" << endl;
std::cout << "addr h:" << h << endl;
std::cout << endl;
func3();
}
void func1()
{
int s[64];
int* h = new int[64];
std::cout << "func1:" << endl;
std::cout << "in stack:" << endl;
std::cout << "addr s:" << s << endl;
std::cout << "in heap:" << endl;
std::cout << "addr h:" << h << endl;
std::cout << endl;
func2();
}
int main()
{
func1();
}
运行之后可以发现:
- 编译默认分配的堆地址空间 是高于栈地址空间的.
- heap 堆地址, 逐渐增加. stack 栈地址, 是逐渐减小的.
为什么会这样?
在很久很久以前, 计算机的内存空间很小, 按KB来计算.
每一次内存的分配都要精打细算. 所以堆和栈空间 在分配的时候会往不同的方向发展, 这样就可以避免地址撞车了.