问题主要出现在对寄存器堆栈的使用上。下面是一个代码示例,说明如何正确地使用PUSH和POP指令来实现斐波那契数列的计算:
fib: PUSH {r4, lr} ; 保存当前的状态,即当前函数返回地址以及r4寄存器的值 MOV r4, #1 ; 斐波那契数列中的第一个和第二个数字都是1 CMP r0, #1 ; 如果要求的数字是1或2,则直接返回值1 ITT LT MOVEQ r0, #1 BXEQ LR MOV r5, #1 ; 将r5寄存器设为1,计数器 MOV r6, #1 ; 将r6寄存器设为1 loop: ADD r7, r4, r6 ; 将前两个数字相加 MOV r4, r6 ; 将r6赋值给r4,以便处理下一个斐波那契数 MOV r6, r7 ; 将r7赋值给r6,以便处理下一个斐波那契数 ADD r5, #1 ; 计数器加1 CMP r5, r0 ; 检查是否完成所有工作 BNE loop ; 如果没有,则跳回"loop"标签处进行下一次循环 MOV r0, r4 ; 返回r4作为结果 POP {r4, pc} ; 回收存储在堆栈中的寄存器
上一篇:ARM汇编-BLT指令