用c++确定计算机上栈的增长方式

栈的增长方式有两种:向上 和 向下

为什么栈会有两种增长方式?

一般程序的变量都是从RAM的低地址开始分配的,变量从低地址开始分配的原因是很明显的,它可以在RAM容量增大时不用从新编译程序。早期的计算机系统的内存容量有限,将堆栈设计成从高地址向低地址增长,可以有限地利用所有的内存容量;同时在变量数目改变的时候,可以保持堆栈的起始地址不变。

现今内存容量变得越来越大,上述的安排就变得逐渐失去了意义;今天即使可以使用从低地址向高地址增长的堆栈,但应该很少会有人用,人们已经习惯成自然了。

c++的一种测试方法:


#include <stdio.h>

void foo(int num) {
printf(“%p\n”, (void*)&num);
if (!num) foo(1);
}

int main(void) {
foo(0);
return 0;
}

第二次的值小于第一次的。

即用递归的方式对函数的参数压栈,然后输出不同层的地址,即可得出栈的增长方向。

ref:

http://www.geminikwok.com/2011/04/02/%E7%94%A8c%E7%A1%AE%E5%AE%9A%E8%AE%A1%E7%AE%97%E6%9C%BA%E4%B8%8A%E6%A0%88%E7%9A%84%E5%A2%9E%E9%95%BF%E6%96%B9%E5%BC%8F/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值