试设计一汇编程序,完成两个长补码的加法(有符号数加法),其中两个长补码的长度是相同的,并且采用低地址存放低位,高地址存放高位的方式存储。对于加法功能,使用子程序实现,两个长补码的起始地址、长补码的长度

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

以下是定义好的数据段和堆栈段:
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

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计算每个加数所占字节数,len不占用内存
    sum db len dup(0)     ;用于保存运算结果
data ends

stack segment stack      ;子程序设计必须定义堆栈段
    dw   40  dup(0)
stack ends

code segment 
   
start:

    mov ax, data
    mov ds, ax
    mov di,0;初始化偏移量

    mov cx,len ;定义循环次数为len=8 
    clc   ;将CF置0
    Lop:
    mov al,sum[di]
    push ax    ;由于栈段为word 所以压入时也为一个字
    mov al,var1[di]
    push ax    ;由于栈段为word 所以压入时也为一个字
    mov al,var2[di]
    push ax    ;由于栈段为word 所以压入时也为一个字
    call Longnumadd
    inc di      ;di自增
    Loop Lop
    mov ax, 4c00h ; exit to operating system.
    int 21h  
   Longnumadd proc
       
      mov bp,sp;//bp为栈基址寄存器,方便操作
      mov  al,[bp+4]  ;为之前压入栈的var1[di]
      mov  bl,[bp+2]  ;为之前压入栈的var2[di]
      adc  al,bl      ;带之前CF的加法相当于al=al+bl+CF
      mov  sum[di],al
      
      ret 6
      
   Longnumadd endp   
ends

end start ; set entry point and stop the assembler.
  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值