汇编--算术运算类指令

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了汇编--算术运算类指令相关的知识,希望对你有一定的参考价值。

加法指令:ADD、ADC、INC

减法指令:SUB、SBB、DEC、NEG、CMP

乘法指令:MUL、IMUL

除法指令:DIV、IDIV

十进制调整指令:DAA、DAS、AAA、AAS、AAM、AAD


 

加法指令: ADD

带进位加法指令:ADC

加一指令:   INC

注意: 除 INC 指令不影响 CF 标志外,均对条件标志位有影响。


 

 结果为0   ZF=1       结果为负   SF=1

CF 位表示 无符号数 相加的溢出。   和的最高有效位 有 向高位的进位

OF 位表示 带符号数 相加的溢出。  

  • 两个操作数符号相同,而结果符号与之相反     
  • 两个操作数符号相反,而结果的符号与减数相同

 

减法指令: SUB(subtract)

带借位减法指令:SBB         SBB指令主要与SUB配合,实现多精度减法运算

减一指令: DEC(decrement)

求补指令: NEG    OPR       求补运算也可以表达成:将操作数按位取反后加1,忘记加1了。

比较指令: CMP    OPR1,OPR2       

 INC指令和DEC指令都是单操作数指令, 主要用于对计数器和地址指针的调整

 

NEG 指令对CF/OF的影响    求补后 

  • 操作数为0   CF=0  否则为1
  • 操作数为 -128 (字节运算)或 操作数为 -32768 (字运算)   OF=1  否则为1

 

CMP指令执行的功能与SUB指令相同,但结果不回送目的操作数


无符号数乘法指令:   MUL

带符号数乘法指令:   IMUL

无符号数乘法指令: MUL SRC 执行操作:

  • 字节操作数 ( AX ) ? ( AL ) * ( SRC )
  • 字操作数 ( DX , AX ) ? ( AX ) * ( SRC )

带符号数乘法指令: IMUL SRC

乘法指令利用OF和CF判断乘积的高一半是否具有有效数值

MUL指令——若乘积的高一半(AH或DX)为0,则OF=CF=0;否则OF=CF=1

IMUL指令——若乘积的高一半是低一半的符号扩展,则OF=CF=0;否则均为1

乘法指令对其他状态标识没有定义

对标志没有定义:指令执行后这些标志是任意的、不可预测(就是谁也不知道是0还是1)

对标志没有影响:指令执行不改变标志状态

 


 

除法

DIV是无符号数除法 DIV;完成两个无符号数相除。

IDIV 是有符号数除法指令,完成两个有符号数相除。

 

无符号数除法指令: DIV SRC 执行操作:

  字节操作:( AL ) ? ( AX ) / ( SRC ) 的商

        ( AH ) ? ( AX ) / ( SRC ) 的余数

  字操作 : ( AX ) ? ( DX , AX ) / ( SRC ) 的商

        ( DX ) ? ( DX , AX ) / ( SRC ) 的余数

带符号数除法指令: IDIV SRC

注意:

  • AX ( DX , AX ) 为隐含的被除数寄存器。
  • AL ( AX ) 为隐含的商寄存器。
  • AH ( DX ) 为隐含的余数寄存器。
  • SRC 不能为立即数。
  • 对所有条件标志位均 无定义。

除法指令对标志没有定义 除法指令会产生结果溢出

除法错中断   被除数远大于除数时候,就会产生编号为0的溢出。


 

十进制调整指令

十进制数调整指令对二进制运算的结果进行十进制调整,以得到十进制的运算结果

分成压缩BCD码和非压缩BCD码调整

压缩BCD码就是通常的8421码;它用4个二进制位表示一个十进制位,一个字节可以表示两个十进制位,即00~99

非压缩BCD码用8个二进制位表示一个十进制位,只用低4个二进制位表示一个十进制位0~9,高4位任意,通常默认为0   造成浪费

 

压缩BCD码调整指令: DAA、DAS

非压缩BCD码调整指令: AAA、AAS、 AAM、AAD

 

DAA ;AL←将AL的加和调整为压缩BCD码

DAS ;AL←将AL的减差调整为压缩BCD码    还会借1呢?

使用DAA或DAS指令前,应先执行以AL为目的操作数的加法或减法指令

DAA和DAS指令对OF标志无定义,按结果影响其他标志,例如CF反映压缩BCD码相加或减的进位或借位状态

 

 

add al,bl     ;二进制加法:al=68h+28h=90h

daa            ;十进制调整:al=96h

 

sub al,bl   ;二进制减法:al=68h-28h=40h

das          ;十进制调整:al=40h

 

das ;34-12=22,CF=0

das ;12-46=66,CF=1

 

 

AAA ;AL←将AL的加和调整为非压缩BCD码 ;AH←AH+调整的进位

AAS ;AL←将AL的减差调整为非压缩BCD码 ;AH←AH-调整的借位

使用AAA或AAS指令前,应先执行以AL为目的操作数的加法或减法指令

AAA和AAS指令在调整中产生了进位或借位,则AH要加上进位或减去借位,同时CF=AF=1,否则CF=AF=0;它们对其他标志无定义

 

 

mov ax,0608h ;ax=0608h,非压缩BCD码表示真值68

mov bl,09h ;bl=09h,非压缩BCD码表示真值9

 

add al,bl ;二进制加法:al=08h+09h=11h

aaa ;十进制调整:ax=0707h;实现非压缩BCD码加法:68+9=77

 

 

sub al,bl ;二进制减法:al=08h-09h=ffh

aas ;十进制调整:ax=0509h ;实现非压缩BCD码减法:68-9=59

 

 

AAM ;AX←将AX的乘积调整为非压缩BCD码

AAD ;AX←将AX中非压缩BCD码扩展成二进制数

  • AAM指令跟在字节乘MUL之后,将乘积调整为非压缩BCD码
  • AAD指令跟在字节除DIV之前,先将非压缩BCD码的被除数调整为二进制数
  • AAM和AAD指令根据结果设置SF、ZF和PF,但对OF、CF和AF无定义

 

mul bl ;二进制乘法:al=08h×09h=0048h

aam ;十进制调整:ax=0702h ;实现非压缩BCD码乘法:8×9=72

 

aam ;二进制扩展:ax=68=0044h

div bl ;除法运算:商al=07h,余数ah=05h ;实现非压缩BCD码初法: 68÷9=7(余5)

 

以上是关于汇编--算术运算类指令的主要内容,如果未能解决你的问题,请参考以下文章

汇编语言通用数据处理指令——算术运算类指令

汇编语言通用数据处理指令——位操作类指令

汇编语言通用数据处理指令——位操作类指令

16位汇编第五讲各种指令详解第一讲

编程中有那些逻辑运算指令

汇编--逻辑指令