gpt4 book ai didi

assembly - 标记堆栈局部变量(asm)

转载 作者:行者123 更新时间:2023-12-02 18:19:17 27 4
gpt4 key购买 nike

在 ASM 函数中,可以使用堆栈为变量创建本地工作区。

我想知道的是,您是否可以创建标签来引用它们,而不是使用堆栈指针的显式数字偏移量?

例如:有人想要 ldr r0, sp+4 但使用符号名称代替?这样做的正确方法是什么?我无法想象人们会记住所有内容的数字偏移量。

最佳答案

I can't imagine people remembering numeric offsets for everything.

所有汇编器都允许对全局变量使用标签,部分出于这个原因,全局变量通常用于汇编类(class)编程,其中命名的局部变量将在高级语言中使用。

还因为全局变量是使用相对简单的数据声明来分配和初始化的,而使用堆栈存储来存储局部变量则需要动态分配、初始化和释放,当然,还需要相对于堆栈指针的偏移量,而不是通过命名标签进行绝对寻址。虽然我们在一般编程中倾向于不赞成全局变量,但许多玩具/赋值程序只有一个 main 和很少或没有函数,因此全局存储实际上是合理的。

许多局部变量和参数都映射到大多数现代机器上的寄存器。有必要确定用于变量、临时变量和参数传递的寄存器,并且使用某种 #define 或 equate 通常会使这变得更困难而不是更容易。许多程序员更喜欢在注释中描述变量及其映射,而不是使用宏或等式。

内存是标量变量映射的最后手段,因为寄存器是首选。如今,我们在 assembly 中进行了最少的必要量(有时根本不进行)。正如已经指出的,在编写玩具程序时,我们可以用全局变量替换局部变量。在这些原因中,使用偏移量并没有您想象的那么严重。


还有一个原因是,给定局部变量的映射在其所在函数的运行过程中发生变化,因此必须根据情况进行调整(例如,有时由于调用约定的原因,参数会移动到另一个寄存器;其他时候从内存到寄存器以提高性能;如果我们不想要帧指针的开销,那么推送将更改堆栈上已有内容的偏移量)。汇编语言的级别非常低,我们通常不想掩盖细节。

关于assembly - 标记堆栈局部变量(asm),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71098440/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com