微型计算机原理与接口技术——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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • APAP INCLUDE「建议收藏」

    APAP INCLUDE「建议收藏」*&———————————————————————**&ReportYMWXBINCLUDE*&*&———————————————————————**&…

    2022年9月22日
    2
  • 使用CCUserDefault 推断用户是否是第一次登陆系统及UserDefault全路径的获取「建议收藏」

    使用CCUserDefault 推断用户是否是第一次登陆系统及UserDefault全路径的获取

    2022年2月1日
    45
  • 性能测试方案设计_性能测试方案模板

    性能测试方案设计_性能测试方案模板1、概述1.1目的本部分主要是针对即将进行性能测试的对象(接口、模块、进程或系统)进行概要的说明,让人明白该测试对象的主要功能与作用及相关业务背景。同时要指出进行性能测试的驱动原因。1.2名词解释此方案中涉及的业务和技术方面的专业名词。1.3参考资料此方案参考和依据的所有文档2、测试对象的拓扑结构本部分主要以图表加文字的方式,对待测试对象(接口、模块、系统)的拓扑结构进行描述,并标上必要的数…

    2025年8月14日
    3
  • RegisterStartupScript 用法

    RegisterStartupScript 用法ClientScript.RegisterStartupScript方法有3个重载:1:RegisterStartupScript(Page,String,String)向ScriptManager控件注册一个启动脚本块并将该脚本块添加到页面中。需要向第三个参数添加脚本标签。第一个参数为页面Page。第二个脚本函数的名字,随便起。第三个是形式的脚本内容。2:RegisterS

    2022年7月20日
    12
  • 首个可用于深度学习的ToF相关数据集!基于置信度的立体相机以及ToF相机深度图融合框架…

    首个可用于深度学习的ToF相关数据集!基于置信度的立体相机以及ToF相机深度图融合框架…点击上方“计算机视觉工坊”,选择“星标”干货第一时间送达作者|cocoon编辑|3D视觉开发者社区目录✦contents1.概述2.方法以及网络结构2.1使用网络学习置信度2.1.1训练细节2.2双目以及ToF视差的fusion3.合成数据4.实验结果4.1测试集场景4.2置信度估计结果4.3视差估计定性以及定量结果5.参考文献附录:数据…

    2022年5月25日
    38
  • IDEA中Maven依赖包下载不了的问题解决方案汇总「建议收藏」

    IDEA中Maven依赖包下载不了的问题解决方案汇总「建议收藏」这个依赖包下载不了的问题真的是很烦,之前一直把下载不上的依赖剪切再粘贴到pom.xml文件中,保存它就自动下载了,但是今天怎么剪切粘贴都没用,所以就花了点时间在网上各种搜解决方案,试了一些之后终于从根本上解决了问题,所以写个博客把解决这个问题的方案汇总一下!1.先是对图上的两个位置一番狂点进行刷新,然并卵…于是又按照博客上的指示去寻找Settings->Build,Executi…

    2022年8月22日
    10

发表回复

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

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