作业一:实现两个64位数相减
代码如下:
.text
.globl _start
_start:
@实现两个64位数相减
@第一个64位数:高32位用r0=0x6表示,低32位用r1 = 0x4表示
@第二个64位数:高32位用r2=0x2表示,低32位用r3 = 0x5表示
@实现两个64位数相加:高32位用r5表示,低32位相加r4表示
@ r4 = r1 - r3 = 0x4 - 0x5 = 0xffffffff
@ r5 = r0 - r2 = 0x6 - 0x2 - 1 = 0x3
mov r0, #0x6
mov r1, #0x4
mov r2, #0x2
mov r3, #0x5
subs r4,r1,r3
sbc r5,r0,r2
stop:
b stop
.end结果如图:

作业二:求两个数最大公约数
代码如下:
.text
.globl _start
_start:
mov r0, #9
mov r1, #15
start:
cmp r0,r1
beq stop
subhi r0,r0,r1
subcc r1,r1,r0
b start
stop:
b stop
.end结果如图

作业三:实现for循环1~100之间 代码如下:
.text
.globl _start
_start:
mov r0, #0
mov r1, #1
mov r2, #100
mov r3, #1
start:
cmp r1,r2
bhi stop
add r0,r1
add r1,r3
b start
stop:
b stop
.end
结果如图:

该文展示了三个汇编语言程序,分别实现64位数的相减,求两个数的最大公约数,以及用for循环计算1到100的序列。通过r寄存器的运算,完成了基本的算术逻辑操作。
449

被折叠的 条评论
为什么被折叠?



