这篇文章主要介绍了汇编语言AAD,DAA,DAS用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
这篇文章主要介绍了汇编语言AAD,DAA,DAS用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程学习网。
本文标题为:汇编语言AAD,DAA,DAS用法解析


基础教程推荐
- ruby on rails validates 2023-09-22
- Swift初始化器与可选链的使用方法介绍 2023-07-08
- Ruby3多线程并行Ractor使用方法详解 2023-07-23
- ruby-on-rails-为使用Rails 4,nginx和乘客的用户设置自定义域 2023-09-21
- win10下使用virtualbox + vagrant配置ruby开发机环境 2023-07-23
- 浅析ELF转二进制允许把 Binary 文件加载到任意位置 2023-07-06
- R语言-修改(替换)因子变量的元素操作 2022-11-26
- Swift中重写和重载的使用与对比总结 2023-07-05
- R语言绘制折线图实例分析 2022-11-21
- R语言 ggplot2改变柱状图的顺序操作 2022-11-17