逻辑运算指令和移位指令

逻辑运算指令和移位指令ANDXORTESTSHLSALROLRCLOR

大家好,又见面了,我是你们的朋友全栈君。

AND XOR TEST SHL SAL ROL RCL
OR NOT SHR SAR ROR RCR

 

AND, OR , XORTEST都是双字节操作指令,操作数的寻址方式的规定与算术运算指令相同.

NOT是单字节操作指令,不允许使用立即数.

逻辑运算均是按位进行操作,真值表如下:

AND (位与&) OR ( 位或| ) XOR  ( 位异或^ )  

1 & 1 = 1

1 & 0 = 0

0 & 1 = 0

0 & 0 = 0

1 | 1 = 1

1 | 0 = 1

0 | 1 = 1

0 | 0 = 0

1 ^ 1 = 0

1 ^ 0 = 1

0 ^ 1 = 1

0 ^ 0 = 0

 

 

 

A:逻辑运算指令

AND (and) 逻辑与指令

AND    DST , SRC           //Byte/Word

执行操作dst = dst & src

1.AND指令执行后,将使CF=0,OF=0,AF位无定义,指令执行结果影响SF,ZFPF标志位.

2.AND指令典型用法A:用于屏蔽某些位,即使某些位为0.

屏蔽AL的高4位:即将高4位和0000B相与,4位和1111B相与

MOV AL , 39H     //AL= 0011 1001B[39H]

ADD AL , 0FH    // AL= 0000 1001B[09H]  0011 1001B[39H]  &  0000 1111B[0FH] = 0000 1001B[09H]

3.AND指令典型用法B:取出某一位的值(见TEST)

 

  

OR (or) 逻辑或指令

OR    DST ,  SRC         //Byte/Word

执行操作:dst = dst | src

1.OR指令执行后,将使CF=0, OF=0, AF位无定义,指令执行结果影响SF, ZFPF标志位.

2.常用于将某些位置1.

AL的第5位置1:

MOV AL , 4AH    // AL=0100 1010B[4AH]

OR    AL , 10H      // AL=0101 1010B[5AH]   0100 1010B[4AH]  |  0001 0000B[10H] =0101 1010B [5AH]

 

  

XOR (eXclusive OR) 逻辑异或指令

XOR    DST , SRC        //Byte/Word

执行操作:dst = dst ^ src

1.XOR指令常用于使某个操作数清零,同时使CF=0,清除进位标志.

2.XOR指令使某些位维持不变则与 ‘0’ 相异或,若要使某些位取反则与 ‘1’相异或.

AL的高4位维持不变,低4位取反:

MOV AL, B8H    //AL=1011 1000B[B8H]

XOR  AL, 0FH    //AL=1011 0111B[B7H]1011 1000B[B8H] ^ 0000 1111[0FH]=1011 0111B[B7H]

测试某一个操作数是否与另一确定操作数相等:

XOR    AX , 042EH

JZ       ….   //如果AX==042EH,ZF=TRUE(1), 执行JZ…

 

NOT (not) 逻辑非指令

NOT    OPR                        //Byte/Word

执行操作:opr = ~opr   // ~ 01100101 [65H] =10011010 [9AH]

1.操作数不能使用立即数或段寄存器操作数,可使用通用寄存器和各种方式寻址的存储器操作数.

2.NOT指令不影响任何标志位。

将AL各位取反:

MOV AL,65H    //AL=0110 0101B[65H]

NOT AL             //AL=1001 1010B[9AH] ~ 0110 0101B[65H]=1001 1010B[9AH]

 

 

TEST (test) 指令

TEST    OPR1 , OPR2        //Byte/Word

执行操作:opr1 & opr2

1.两个操作数相与的结果不保存,结果影响标志位PF,SFZF,使CF=0, OF=0,AF位无定义.

2.TEST指令常用于在不改变原有的操作数的情况下,检测某一位或某几位的条件是否满足.只要令用来测试的操作数对应检测位为1,其余位为0,相与后判断零标志ZF值的真假.

检测某位是否为1:

令用来测试的操作数对应检测位为1,其余位为0,TEST指令后,若该位为1则 JNZ

TEST AL , 0000 00001B   //测试AL最低位是否为1:: 令用来测试的操作数对应检测位为1,其余位为0,执行TEST指令 

JNZ   THER     //最低位若为1,ZF=FALSE(0), 执行JNZ THER, 否则执行下一条指令.

或者:先对操作数求反,令用来测试的操作数对应检测位为1,其余位为0,TEST指令后,若该位为1则JZ…

MOV    DL , AL    //AL 传送到DL,主要是不要影响AL的值.   以下测试ALb2位是否为1

NOT    DL     //先对操作数求反

TEST    0000 0100B //令用来测试的操作数对应检测位为1,其余位为0,执行TEST指令

JZ    THER        //ALb2位为1,ZF=TRUE(1), 执行JZ    THER

  

  

 

B移位指令[所有的移位指令都影响标志位CFOFPFSFZF.AF无定义.]

非循环逻辑移位把操作数看成无符数来进行移位.

SHL ( SHift logical Left )逻辑左移指令

SHL    OPR , CNT     //Byte/Word

执行操作:使OPR左移CNT位,并使最低CNT位为全0.

1.OPR操作数不能使用立即数或段寄存器操作数,可使用通用寄存器和各种方式寻址的存储器操作数.

2.移位次数由CNT决定.每次将OPR的最高位移出并移到CF,最低位补0.

MOV  CL , 7            //若移位多次, 先预置移位次数CL

SHL    DX ,  CL       //CNT可取1CL寄存器操作数

 

SHR (SHift logical Right) 逻辑右移指令

SHR    OPR , CNT        //Byte/Word

同SHL,每次将OPR的最低位D0移出并移到CF.最高位补0.

 

 

非循环算术移位将操作数看成有符号数来进行移位.

SAL (Shift Arithmetic Left) 算术左移指令

SAL    OPR , CNT         //Byte/Word

SAL指令与SHL指令完全相同

 

SAR(Shift Arithmetic Right) 算术右移指令

SAR    OPR , CNT        //Byte/Word

SAR指令每次移位时,将最高位移入次高位的同时最高位值不变,最低位D0移出并移到CF.

 

 

循环移位指令

ROL ( ROtate Left) 循环左移指令

ROL    OPR , CNT        //Byte/Word

每次移位时,最高位移出并同时移到CF和最低位D0.

 

ROR (ROtate Right)循环右移指令

ROR    OPR,CNT    //Byte/Word

每次移位时,最低位D0移出并同时移到CF和最高位.

 

 

带进位循环移位指令

RCL (Rotate Left through Carry)带进位循环左移指令

RCL    OPR,CNT     //Byte/Word

 

RCR (Rotate Right through Carry)带进位循环左移指令

RCR    OPR ,CNT       //Byte/Word

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/142796.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 新式单片机视频教程下载

    新式单片机视频教程下载新式单片机视频教程下载点击此处进入下载页面【文件名称】——国内首创新式单片机视频教程【文件描述】单片机学习资料,新手绝佳教程….【注意事项】压缩包内为种子文件需使用BT类软件下载;转载自btpig.com。–注:1.本人发资源纯为与诸位共享,发布前均做过测试保证可用。2.如果下载后打不开请重新再试,可能是网络传输问题。3.如有疑问请访问【http://blog.csdn.net/soft

    2022年4月28日
    48
  • 初学者编写python用什么软件[通俗易懂]

    初学者编写python用什么软件[通俗易懂]初学者编写python用什么软件以下是常用的几款Python代码编辑器和Python集成开发工具。一、Python代码编辑器1.SublimeTextSubl…

    2022年5月26日
    36
  • 桥接模式

    桥接模式

    2022年1月2日
    49
  • DTCC 2019 | 深度解码阿里数据库实现 数据库内核——基于HLC的分布式事务实现深度剖析…

    DTCC 2019 | 深度解码阿里数据库实现 数据库内核——基于HLC的分布式事务实现深度剖析…

    2021年7月7日
    87
  • ac测评题库_ftb任务指令

    ac测评题库_ftb任务指令有两台机器 A,B 以及 K 个任务。机器 A 有 N 种不同的模式(模式 0∼N−1),机器 B 有 M 种不同的模式(模式 0∼M−1)。两台机器最开始都处于模式 0。每个任务既可以在 A 上执行,也可以在 B 上执行。对于每个任务 i,给定两个整数 a[i] 和 b[i],表示如果该任务在 A 上执行,需要设置模式为 a[i],如果在 B 上执行,需要模式为 b[i]。任务可以以任意顺序被执行,但每台机器转换一次模式就要重启一次。求怎样分配任务并合理安排顺序,能使机器重启次数最少。输入格

    2022年8月9日
    6
  • OkGo使用缓存(苹果清理缓存)

    添加依赖:implementation’com.lzy.net:okgo:3.0.4’添加网络权限:<uses-permissionandroid:name="android.permission.INTERNET"/>准备网络数据:使用:OkGo.getInstance().init(getApplication()…

    2022年4月12日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号