汇编:子程序

这篇博客介绍了如何用汇编语言编写一个子程序,来完成相同长度的两个长补码有符号数的加法。采用低地址存低位、高地址存高位的存储方式,并通过堆栈传递参数,特别是利用adc指令进行带进位的加法运算,循环处理每个字节。数据段和堆栈段已定义,提示可用clc指令初始化进位标志位CF。
摘要由CSDN通过智能技术生成

完成两个长补码的加法(有符号数加法),其中两个长补码的长度是相同的,并且采用低地址存放低位,高地址存放高位的方式存储。对于加法功能,使用子程序实现,两个长补码的起始地址、长补码的长度(以字节为单位)、运算结果的起始地址均由主程序以入口参数的形式传递给子程序。
注意,参数传递方式必须采用堆栈传递方式。
以下是定义好的数据段和堆栈段:

data segment
var1 db 92h, 95h, 12h, 71h, 08h, 27h, 92h, 0c3h
 ;变量 var1 保存长度为 8 个字节的有符号数 1
var2 db 8eh, 3dh, 0c2h, 0abh,7ah, 35h, 0a5h, 09h ;变量 var2 保存长度为 8 个字节的有符号数 2
len equ $-var2
 ;len 计算每个加数所占字节数,len 不占用内存
sum db len dup(0)
 ;用于保存运算结果
data ends
stack1 segment stack
dw
 40
 dup(0)
stack1 ends
;子程序设计必须定义堆栈段

注:可考虑使用循环结构来实现以上长补码的加法,每次循环中数 1 和数 2 的一个字节相加,且使用 adc 指令来实现加法的运算。(提示:adc 指令是带进位的加法指令,它需要利用 CF 标志位上记录的进位值。第一次使用adc 指令之前,需要用 clc 指令将 CF 位置 0)

源代码

assume cs:code, ds:data, ss:stack
data segment
var1 db 92h, 95h, 12h, 71h, 08h, 27h, 92h, 0c3h     ;变量 var1 保存长度为 8 个字节的有符号数 1   
var2 db 8eh, 3dh, 0c2h, 0abh,7ah, 35h, 0a5h, 09h    ;变量 var2 保存长度为 8 个字节的有符号数 2
len equ $-var2                                      ;len 计算每个加数所占字节数, l
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值