当前位置:首页>维修大全>综合>

daa汇编运算方法(汇编语言中如何计算浮点数)

daa汇编运算方法(汇编语言中如何计算浮点数)

更新时间:2025-05-24 20:48:41

daa汇编运算方法

DA A汇编运算方法是指使用寄存器A中的数值与内存中的数据进行相减操作,并将结果存回A寄存器中。

具体实现方法如下:

1. 将要减的数值从内存中加载到寄存器A中。

2. 使用DA指令,将A寄存器中的数值减去一个BCD码,并将结果存在A寄存器中。

3. 如果求差后结果不是BCD码,则将A寄存器中的数值加上6(即加上0100B),并将进位标志设置为1。

4. 如果A寄存器中的数值高四位是BCD码并且进位标志为1,则将A寄存器中的数值高四位加上1(即加上0001B)。

5. 清除其他标志位,完成DA A运算操作。

需注意的是,在DA A运算过程中,只有A寄存器中的数值会发生变化,BCD码的范围为00H~99H,运算结果也必须在这个范围内。

AAD 为下面的除法做准备 ,把AL 和 AH 两个单BCD码组成一个十进制数

1、AAD(调整除)

5.2该指令是在作除法前用于调整寄存器AH和AL之值,它是把二个寄存器中单BCD码组成一个十进制数值,其调整规则如下:

AL←AH*10+AL,AH←0

受影响的标志位:PF、SF和ZF(AF、CF和OF等都是无定义)

MOV AX, 0502H MOV BL, 10D AAD          ;AH=0, AL=52H DIV BL        ;AH=2(余数), AL=5(商)

2、DAA(调整加十)

该指令是用于调整AL的值,该值是由指令ADD或ADC运算二个压缩型BCD码所得到的结果。压缩型BCD码是一个字节存放二个BCD码,低四位和高四位都是一个BCD码。其调整规则如下:

如果AL的低四位大于9,或AF=1,那么,AL=AL+06H,并置AF=1;

如果AL的高四位大于9,或CF=1,那么,AL=AL+60H,并置CF=1;

如果以上两点都不成立,则,清除标志位AF和CF。

经过调整后,AL的值仍是压缩型BCD码,即:二个压缩型BCD码相加,并进行调整后,得到的结果还是压缩型BCD码。

受影响的标志位:AF、CF、PF、SF和ZF(OF无定义)

MOV AL, 43H MOV BL, 29H ADD AL, BL     ;AL=6CH,其不是压缩型的BCD码,因为低四位‘B‘不是BCD码 DAA          ;调整后,AL=72H,这是压缩型的BCD码,也有:43+29=72

3、DAS(调整减十)

该指令也是用于调整AL的值,AL是由指令SUB或SBB运算二个压缩型BCD码所得到的结果。其调整规则如下:

如果AL的低四位大于9,或AF=1,那么,AL=AL-06H,并置AF=1;

如果AL的高四位大于9,或CF=1,那么,AL=AL-60H,并置CF=1;

如果以上两点都不成立,则,清除标志位AF和CF。

经过调整后,AL的值仍是压缩型BCD码,即:二个压缩型BCD码相减,并进行调整后,得到的结果还是压缩型BCD码。

受影响的标志位:AF、CF、PF、SF和ZF(OF无定义)

MOV AL, 43H MOV BL, 29H SUB AL, BL    ;AL=1AH,其不是压缩型的BCD码,因为低四位‘A‘不是BCD码 DAS        ;调整后,AL=14H,这是压缩型的BCD码,也有:43-29=14

以上就是本文的全部内容,希望对大家的学习有所帮助。

更多栏目