2023-2-15作业

题目:

1.实现两个64位数相减

2.求两个数最大公约数

3.实现for循环1~100之间


1.

.text	@文本段
.globl _start	@声明一个_start全局函数

_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
	
	ldr r0,= 0x6
	ldr r1,= 0x4
	ldr r2,= 0x2
	ldr r3,= 0x5
	
	subs r4,r1,r3
	sbc r5,r0,r2
	
stop:	@stop标签的入口,相当于C语言中的while(1)
	b stop
.end	@结束标志

2.

.text	@文本段
.globl _start	@声明一个_start全局函数

_start:	@_start标签入口
	
	mov r0, #9
	mov r1, #15
	
	cmp r0,r1	
	blne Loop
	cmp r0,r1
	beq stop
Loop:
	subhi r0,r0,r1
	subcc r1,r1,r0
	mov pc,lr
	
stop:	@stop标签的入口,相当于C语言中的while(1)
	b stop
.end	@结束标志

3.

.text	@文本段
.globl _start	@声明一个_start全局函数

_start:	@_start标签入口
	
	mov r0, #1
	
	cmp r0, #100
	blcc Loop
	
	cmp r0, #100
	bhi stop
Loop:	
	add r1,r1,r0
	add r0,r0,#1
	mov pc,lr
	
stop:	@stop标签的入口,相当于C语言中的while(1)
	b stop
.end	@结束标志

运行结果:

1.

 2.

 3.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值