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
以上就是本文的全部内容,希望对大家的学习有所帮助。