微型计算机原理与接口技术——8086指令系统之移位指令

微型计算机原理与接口技术——8086指令系统之移位指令移位指令移动一位时由指令直接给出;移动两位及以上,则移位次数由CL指定。要求操作数不能是立即数;这类指令的执行大多会影响6个状态标志位。非循环移位指令逻辑左移SHL(ShiftLogicLeft)算术左移SAL(ShiftArithmeticLeft)逻辑右移SHR(ShiftLogicRight)算术右移SAR(ShiftArithmeticRight)4条指令的格式完全相同,可实现对8位或16位寄存器操作数或内存操作数进行指定次数的移位。逻辑移位指令针对的

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

移位指令

  • 移动一位时由指令直接给出;
  • 移动两位及以上,则移位次数由CL指定。
  • 要求操作数不能是立即数;
  • 这类指令的执行大多会影响6个状态标志位。

非循环移位指令

  • 逻辑左移SHL(Shift Logic Left)
  • 算术左移SAL(Shift Arithmetic Left)
  • 逻辑右移SHR(Shift Logic Right)
  • 算术右移SAR(Shift Arithmetic Right )

4条指令的格式完全相同,可实现对8位或16位寄存器操作数或内存操作数进行指定次数的移位。

逻辑移位指令针对的是无符号数,算术移位指令针对有符号数。

算术左移和逻辑左移

  • 算术左移指令:
    SAL OPRD,1
    SAL OPRD,CL

  • 逻辑左移指令:
    SHL OPRD,1
    SHL OPRD,CL

在这里插入图片描述

逻辑右移

在这里插入图片描述
移动一位后,若最高位与次高位相同,则OF=0;否则OF=1。

SHR指令实现无符号数右移一位÷2。

例:
在这里插入图片描述

算术右移

在这里插入图片描述
SAR指令实现带符号数右移一位÷2

循环移位指令

在这里插入图片描述
在这里插入图片描述

指令格式、对操作数的要求与非循环移位指令相同

不带CF的循环左移指令ROL

格式

ROL OPRD,1
ROL OPRD,CL

操作

ROL指令将目标操作数向左循环移动一位或由CL指定的位数,最高位移入CF,同时再移入最低位构成循环,进位标志不在循环之内。

对标志位的影响同SAL/ SHL指令

例:
在这里插入图片描述

不带CF的循环右移指令ROR

格式

ROR OPRD,1
ROR OPRD,CL

操作

ROR指令将目标操作数向右循环移动一位或CL指定的位数,最低位移入CF,同时再移入最高位构成循环,进位标志不在循环之内。

对标志位的影响同SHR指令

带CF的循环左移指令RCL

格式

RCL OPRD,1
RCL OPRD,CL

操作

RCL指令将目标操作数连同进位标志位CF一起向左循环移动一位或CL指定的位数,最高位移入CF,而CF原来的值移入最低位。

对标志位的影响同ROL指令

带CF的循环右移指令RCR

格式

RCR OPRD,1
RCR OPRD,CL

操作

RCR指令将目标操作数连同进位标志位CF一起向右循环移动一位或CL指定的位数,最低位移入CF,而CF原来的值移入最高位。

对标志位的影响同ROR指令

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

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

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


相关推荐

  • calendar类的方法_unsafe类常用方法

    calendar类的方法_unsafe类常用方法概念java.util.Claendar日历类,抽象类,在Date类后出现的,替换掉了很多Date类中的方法,该类将所有的可能用到的时间信息封装为静态成员变量,通过类名.静态成员变量获取时间字段值获取方式由于Calendar类是一个抽象类,语言敏感性,Calendar类并不是直接创建对象来获取时间属性值,而是通过静态方法创建,返回子类对象。静态方法如下:publicstaticCalendargetInstance();使用默认时区和默认的语言环境获取一个对象…

    2022年9月23日
    3
  • sun.misc.BASE64Encoder报错解决方法[通俗易懂]

    sun.misc.BASE64Encoder报错解决方法[通俗易懂]用java.util.Base64代替即可。原代码:BASE64Encoderencoder=newBASE64Encoder();returnencoder.encode(data);改为:Base64.Encoderencoder=Base64.getEncoder();returnencoder.encodeToString(data);

    2022年6月17日
    104
  • JavaScript下载本地文件

    JavaScript下载本地文件网上很多关于JS下载文件操作的代码,都过于繁杂,偶然找到这个方法,务必记录一下,太简单实用了/Template/MaterielDictionary.xlsx为文件相对路径,后边参数可不动。window.open(‘/Template/MaterielDictionary.xlsx’,’newwindow’,’height=100,width=400,top=0

    2022年6月10日
    172
  • 什么是大数据架构?需要学什么内容?[通俗易懂]

    什么是大数据架构?需要学什么内容?[通俗易懂]大数据架构设计用来处理对传统数据库系统而言太大或太复杂的数据的引入、处理和分析。组织进入大数据领域的门槛各不相同,具体取决于用户的权限及其工具的功能。对某些组织来说,大数据可能意味着数百个GB的数据,而对另一些组织来说,大数据则意味着数百个TB的数据。随着处理大数据集的工具的发展,大数据的涵义也在不断地变化。慢慢地,这个术语更多的是指通过高级分析从数据集获取的价值,而不是严格地指数据的大小…

    2022年5月16日
    36
  • 标准红外遥控的接收程序-松瀚汇编源程序

    标准红外遥控的接收程序-松瀚汇编源程序

    2021年12月5日
    52
  • name python3 is not defined_python cannot import name

    name python3 is not defined_python cannot import name在编辑代码时,如果需要采用非本代码所在文件夹下的代码文件的函数或者类时,那么需要添加该代码文件所在路径,否则会报“NameError:name’XXX’isnotdefined”的错误,其实解决方案也非常简单,只要使用sys函数就可以解决:比如在编写的代码中需要使用另外一个文件夹util内的代码文件Reader.py的一个函数,那么只用在头文件下输入如下语句:imports…

    2022年10月2日
    2

发表回复

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

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