当前位置: 首页 > news >正文

ARM 堆栈寻址类型区分

文章目录

      • 堆栈指向分类
      • 堆栈指向数据分类
      • 满递增与满递减
      • 空递增与空递减

堆栈指向分类

根据堆栈指针的指向的方向不同,可以划分为向上生成型和向下生成型。

向上生成型:

  • 随着数据的入栈,堆栈的指针逐渐增大,称为:递增堆栈。

向下生成型:

  • 随着数据的入栈,堆栈的指针逐渐减小,称为:递减堆栈。

堆栈指向数据分类

根据堆栈指针是否指向数据,可以划分为满堆栈和空堆栈。

满堆栈:

  • 堆栈指针指向最后压入堆栈的有效数据项。

空堆栈:

  • 堆栈指针指向下一个要存放数据的空位置。

满递增与满递减

用于描述寄存器或内存中的值在递增或递减操作时,增加或减少一个完整的数据单元的大小。

数据单元的大小通常由操作系统或架构规定,可以是字节、字、双字等。

满递增是按照完整的数据单元大小增加,不论数据单元的大小是多少,递增时都会增加整个数据单元的大小。

满递减是按照完整的数据单元大小递减,不论数据单元的大小是多少,递减时都会减少整个数据单元的大小。

假设在堆栈中存储 R0R1R2 寄存器的值,按照满递增与满递减存储,如下所示:

先进行递增或者递减,然后再存入数据。

空递增与空递减

同样也是用于描述寄存器或内存中的值在递增或递减操作时,增加或减少一个空间单元的大小。

空间单元的大小可能不是完整的数据单元大小,而是根据指定的步长进行增加或减少。

空递增是按照指定的步长或空间单元大小增加,可以根据需要自定义递增步长。

空递减是按照指定的步长或空间单元大小递减,可以根据需要自定义递减步长。

直接指向存入的数据。

http://www.lryc.cn/news/198639.html

相关文章:

  • 每日一练 | 网络工程师软考真题Day43
  • jsonXML格式化核心代码
  • PTQ量化和QAT量化
  • 【Django 02】数据表构建、数据迁移与管理
  • 一天吃透Java集合面试八股文
  • 高级深入--day36
  • Jmeter接口测试工具的一些使用小技巧
  • 黄金眼PAAS化数据服务DIFF测试工具的建设实践 | 京东云技术团队
  • 深入了解RPA业务流程自动化的关键要素
  • CSS记录
  • Kotlin中类型转换
  • P7557 [USACO21OPEN] Acowdemia S
  • 如何确认栈中申请的变量地址
  • 【STM32】--基础了解
  • join、inner join、left join、right join、outer join的区别
  • 小程序中如何使用自定义组件应用及搭建个人中心布局
  • pyest+appium实现APP自动化测试,思路全总结在这里
  • ES6 Set数据结构
  • Semaphore(信号量)
  • InnoDB 与 MyISAM的比较(含其他存储引擎)
  • 系统韧性研究(2)|系统韧性如何关联其他质量属性?
  • 电脑桌面记事本便签软件哪个好?
  • 可视化(Visual) SQL初探
  • 多目标权重融合方式
  • 软件工程与计算总结(二十)软件交付
  • 02 开闭原则
  • LamdaUpdateWapper失效问题
  • “权限之舞:Linux安全之道”
  • Visual Studio Code官网下载、vscode下载很慢、vscode下载不了 解决方案
  • URL、域名和网址的区别