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

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

猜你喜欢

转载自blog.csdn.net/gls_nuaa/article/details/115281756