ARM堆栈满/空,递增递减概念

  今天学习了嵌入式系统的程序设计,碰到堆栈这个概念。比较容易混淆,写这篇用以区分(笔者只学了ARM一种,不知道其他类型是否相同,有了解的可以告诉我下~)。
  首先说一下堆栈的分类:
  根据堆栈指针指向的数据位置的不同,堆栈可分为满堆栈空堆栈

  满堆栈:堆栈指针指向当前最后一个已使用的地址
  空堆栈:堆栈指针指向当前第一个还没有使用的地址(也就是存下一个的时候就用它!)

  另外就是递增递减,总能够看到“满递增、空递增、满递减”这样的说法。

  递增:堆栈指针压入数据的时候,地址从低地址向高地址变化
  递减:堆栈指针压入数据的时候,地址从高地址向低地址变化

  所以满递增的含义就是:堆栈指针指向最后一个压入的数据,并且地址从低到高变化。附上一道相关练习题:
在这里插入图片描述
参考资料:

https://blog.csdn.net/haospark/article/details/80359116
https://blog.csdn.net/itworld123/article/details/88058118
https://blog.csdn.net/zilan23/article/details/104035689

因作者水平有限,如有错误之处,请在下方评论区指出,谢谢!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值