这是涉及汇编语言的微控制器考试的练习题,要求在执行完最后一行后查找累加器中的内容。我不明白答案怎么是 $5C 如果有人有任何汇编知识请帮助我!
START: LDA #$11 ; load accumulator
STA $2123 ; store accumulator to a memory address
CLRA
LDA #$67 ; load accumulator
LDHX #$2120 ; load index register
SUB $03, X ;subtract accumulator using index register
ADD #$06 ; add accumulator
START: LDA #$11 ; load accumulator
- A=$11
STA $2123 ; store accumulator to a memory address
- memory[$2123] = $11
CLRA
- A=$00 (redundant, as next instruction will load A again)
LDA #$67 ; load accumulator
- A=$67
LDHX #$2120 ; load index register
- H:X=$2120
SUB $03, X ;subtract accumulator using index register
- this is addressing mode "Indexed, 8-Bit Offset" (indexed by H:X)
- target memory address is calculated as H:X+$03 = $2123
- finally subtraction is done on A: A=A-memory[$2123] ($67-$11=$56)
ADD #$06 ; add accumulator
- A=A+$06 ($56+$06=$5C)
注意
#$
与$
(立即十六进制值与内存地址/偏移十六进制值)以及汇编器的总体语法(实际上我主要猜测您正在使用哪个CPU和汇编器,看起来像飞思卡尔) HCS08,但你应该更了解,我从来没有为类似的代码编写过代码),因为每个汇编器都可以有如何编写某些机器指令的微妙(不同)细节,并且每个 CPU 都有不同的指令集(哪些指令可用以及如何使用)有效地解决某些编程问题)。
因此,您应该足够了解语法,以正确评估特定行生成的指令,然后您可以检查指令集手册,了解该指令(及其变体)到底做什么。使用调试器进行练习也很有帮助,实际上编写一些小任务并在调试器中单步执行每条指令,将实际结果与您的假设进行比较。