16位汇编第六讲汇编指令详解第第三讲

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了16位汇编第六讲汇编指令详解第第三讲相关的知识,希望对你有一定的参考价值。

                                               16位汇编第六讲汇编指令详解第第三讲

1.十进制调整指令

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

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

简而言之:

         以前的时候你有个手表,里面的数字是九,如果加一个1就是0了,就会产生进位,

不过这个是10进制进位的,所以应该是 a了,但是a的话就出错了.所以我们就出来了这个调整指令直接变为零,然后进位,也就是16进制码当做10进制使用

压缩BCD

         压缩BCD就是4位表示一个数字

非压缩BCD

         非压缩就是一个字节表示一个数字(高4位通常为零)

例子

真值               8        64

二进制编码       08H        40H

压缩BCD码      08H        64H

非压缩BCD码  08H        0604H

可以看出,8如果是个位数,是不变的

如果64那么压缩的是4位表示一个数字非压缩的就是1个字节表示,高位为零.

 

压缩BCD吗的加减调整指令

DAA(加法的调整指令) DAS (减法的调整指令)

DAA 后缀A是Add的意思,后缀s是Sub的意思

例子

mov al,68h

;压缩的BCD码是68

mov bl,28h   压缩的BCD码28

add al,bl  二进制加法,al + bl 赋值为al

daa  (十进制调整)

al = 68h + 28h = 90h

 

但是因为daa了,所以是十进制进位 是96

简单理解就是,本来16进制 9+1 = A的,但是十进制调整,就不能是A了,需要变为0,结果是10了

DAA的内部原理就是遇到a(….) +6

同理DAS也是-6

只不过是通过标志位完成的(辅助标志位)

减法例子:

     

mov al,68h

mov bl,28h

sub al,bl

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

 

;实现压缩BCD码加法:68-28=40

 

非压缩BCD的加,和减法的调整指令

AAA,AAS

例子

         mov ax,0109  (其实是想显示19)

         mov al,1

         aaa 调整al

减法的例子:

        

mov ax,0100h

sub al,1

aas

 

非压缩BCD的乘法,和除法调整指令

AAM,AAD

加法的:

mov ax, 0205h   真值是0205

mov bx, 2             赋值乘数为2

mul bx                  相乘

aam                             调整

 

除法的

         

mov ax, 0102h

mov bl, 2

aad

div bl

 

除法的需要先调整,在相

 

二丶位操作类指令

         分为三类

1.逻辑运算指令

         AND OR XOR NOT TEST

2、移位指令

SHL  SHR  SAR

3、循环移位指令

ROL  ROR  RCL  RCR

 

1.逻辑AND

寻址公式,指令

AND reg,imm/reg/mem ;reg←reg∧imm/reg/mem

AND mem,imm/reg ;mem←mem∧imm/reg

作用:

1.对两个操作数执行逻辑与运算,结果送到目的操作数

2.AND指令设置CF = OF = 0,根据结果设置SF、ZF和PF状态,而对AF未定义

AND 就是C语言的与运算,1 & 1 = 1  1&0 = 0

2.逻辑指令 OR(或运算)

作用:

1.对两个操作数执行逻辑或运算,结果送到目的操作数

2.OR指令设置CF = OF = 0,根据结果设置SF、ZF和PF状态,而对AF未定义

操作指令:

OR reg,imm/reg/mem ;reg←reg∨imm/reg/mem

OR mem,imm/reg ;mem←mem∨imm/reg     

C语言中的或运算

置位用的

3.逻辑异或指令XOR

作用:

对两个操作数执行逻辑异或运算,结果送到目的操作数

XOR指令设置CF = OF = 0,根据结果设置SF、ZF和PF状态,而对AF未定义

 

操作指令:

         XOR reg,imm/reg/mem ;reg←reg⊕imm/reg/mem

XOR mem,imm/reg ;mem←mem⊕imm/reg

C语言中的疑或指令,相同为假,不同为真.

4.逻辑非指令NOT(C语言中的位取反~)

作用:

对一个操作数执行逻辑非运算

NOT指令是一个单操作数指令

NOT指令不影响标志位

操作指令:

         NOT reg/mem ;reg/mem←~reg/mem

 

5.测试指令TEST

作用:

1.对两个操作数执行逻辑与运算,结果不回送到目的操作数

TEST指令和CMP指令类似,CMP指令内部是相减然后设置标志位

而TEST指令是内部相与,然后设置标志位

2.AND指令设置CF = OF = 0,根据结果设置SF、ZF和PF状态,而对AF未定义

 

指令:

         TEST reg,imm/reg/mem                   ;reg∧imm/reg/mem

         TEST mem,imm/reg         ;mem∧imm/reg

测试指令,一般用于零判断

优先使用Test指令,因为TEST指令比CMP指令快一点

 

6.移位指令(shift)

左移指令:

SHL SAL (逻辑左移,和算术左移)

逻辑左移: 移动的时候,补零

         SHL:逻辑左移,最高位进入CF,最低位补0

         SAL:   算术左移,最高位进入CF,最低位补0

其中逻辑左移和算术左移是一样的,一般都会汇编成逻辑左移

算术左移: 移动的时候补符号位(和C语言一样)

作用:

将操作数移动一位或多位,分成逻辑移位和算术移位,分别具有左移或右移操作

操作指令:

         SHL reg/mem,1/CL   (其中CL是次数,在8086的中,移动一次可以直接写,但是移动多次比如放到计数器中)

例如

         SHL al,1  (移动一个可以)

         SHL al,2  (这样不可以,必须放到CL中)

改为

         mov cl,2

         SHL  al,2

右移指令:

SHR reg/mem,1/CL

逻辑右移,最低位进入CF,最高位补0

SAR reg/mem,1/CL

算术右移,最低位进入CF,最高位不变

右移的话不会是一样的,不和左移一样.他会有符号位的区分的.

应用:

         一般来说,逻辑左移,算术左移,逻辑右移,算术右移都有特定的应用

   技术分享

 

 

最高位置CF

 

 技术分享

 

逻辑右移SHR 值CF位补零

SAR则补符号位

 

移位指令对标志的影响

按照移入的位设置进位标志CF

根据移位后的结果影响SF、ZF、PF

对AF没有定义

如果进行一位移动,则按照操作数的最高符号位是否改变,相应设置溢出标志OF:如果移位前的操作数最高位与移位后操作数的最高位不同(有变化),则OF = 1;否则OF = 0。当移位次数大于1时,OF不确定

移位乘法和除法

         逻辑左移一位,相当于无符号的数*2

         逻辑右移一位相当于无符号数/2

 

 

7.循环移位指令

        

 

        

作用:

         将操作数从一端移出的位返回到另一端形成循环,分成不带进位和带进位,分别具有左移或右移操作

指令:

         ROL reg/mem,1/CL ;不带进位循环左移

         ROR reg/mem,1/CL         ;不带进位循环右移

         RCL reg/mem,1/CL ;带进位循环左移

         RCR reg/mem,1/CL ;带进位循环右移

 

不带进位循环左移

 技术分享

 

可以看出,高位有效位(MSB)的高位,给低位了,(相当于高位和低位互换了)然后高位置CF位

不带进位循环右移

 技术分享

 

这个则是相反,低位和高位互换,然后还是高位置CF位

 

带进位的左循环移位RCL

 技术分享

 

这个则是最高位给CF位保存,然后CF位给低位,(相当于中间有一个CF位做中转)

 

带进位的右循环移位RCR

 技术分享

 

这个则是相反,最低位先给CF位保存,CF位再给最高位

一般循环带进位的移位指令,适用于32位数的计算(8086下)

循环移位指令对标志的影响

按照指令功能设置进位标志CF

不影响SF、ZF、PF、AF

如果进行一位移动,则按照操作数的最高符号位是否改变,相应设置溢出标志OF:如果移位前的操作数最高位与移位后操作数的最高位不同(有变化),则OF = 1;否则OF = 0。当移位次数大于1时,OF不确定

 

32位数的计算

 技术分享

 

首先左移一位,最高位置CF位,然后带进位左移一位,CF位则给DX位进位,则产生了进位

资料:

链接:http://pan.baidu.com/s/1jHWF2fG 密码:ykum

以上是关于16位汇编第六讲汇编指令详解第第三讲的主要内容,如果未能解决你的问题,请参考以下文章

16位汇编第三讲 分段存储管理思想

PC逆向之代码还原技术,第六讲汇编中除法代码还原以及原理第二讲,被除数是正数 除数非2的幂

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

32位汇编第三讲,RadAsm,IDE的配置和使用,以及汇编代码注入方式

16位汇编中的伪指令

汇编基础 汇编指令