实验内容
试设计一汇编程序,完成两个长补码的加法(有符号数加法),其中两个长补码的长度是相同的,并且采用低 地址存放低位,高地址存放高位的方式存储。对于加法功能,使用子程序实现,两个长补码的起始地址、长补码的 长度(以字节为单位)、运算结果的起始地址均由主程序以入口参数的形式传递给子程序。注意,参数传递 方式必须采用堆栈传递方式。
以下是定义好的数据段和堆栈段:
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
参考代码:
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
code segment
start:
mov ax, data
mov ds, ax
mov cx, 8 ;设置循环次数
mov di, 0 ;记录循环次数
clc
AddLoop:
mov al, var1[di] ;获取变量1
mov dl, var2[di] ;获取变量2
push ax ;变量1压栈
push dx ;变量2压栈
call long_add ;调用子程序
pop dx ;变量1弹出
pop ax ;变量2弹出
inc di ;循环次数+1
loop AddLoop
mov ax, 4CH ; 程序结束
int 21H
ends
;子程序
long_add proc
mov bp, sp ;获取栈指针
mov bl, [bp + 2] ;读取变量2
adc bl, [bp + 4] ;变量1+变量2+CF
mov sum[di], bl ;存入结果
ret
long_add endp
end start ; set entry point and stop the assembler.
code ends