vs 编译器的堆空间不足_为什么C/C++ 栈空间内存地址 往低处生长?

4ff61f8b27c9904a37bed566b7c03f7b.png

有一点汇编经验的朋友应该知道 push eax的时候, 会先进行esp = esp -4, 然后在把 eax内存入栈. 每push一次 esp就会减少.也就是说栈地址 是往低处生长的.

那么为什么会这样呢?

这可能因为: 堆往高处走, 栈只好委屈一下往"低处流"!

4590beeffa78998366e408cd151a8e4e.png
堆和栈内存示意图

话不多说, 直接上代码, 看的明白!

在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来计算.

每一次内存的分配都要精打细算. 所以堆和栈空间 在分配的时候会往不同的方向发展, 这样就可以避免地址撞车了.

18b8e1b99f55bd1c21652d6db75cdc80.png
未经编译器优化的运行结果
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值