汇编语言实验 汇编程序中的子程序设计

该博客介绍了如何设计一个汇编程序,以完成两个相同长度的长补码有符号数的加法。程序采用低地址存放低位,高地址存放高位的存储方式,并通过堆栈传递参数,包括两个加数的起始地址、长度和运算结果的存储地址。在主程序中,利用循环和子程序调用来逐位进行加法运算,并将结果保存到指定位置。
摘要由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

参考代码:

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

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值