汇编第三章80x86的指令系统和寻址方式.ppt

  1. 1、本文档共157页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
汇编第三章80x86的指令系统和寻址方式

第3章 80x86的指令系统和寻址方式 § 3.1 80x86的寻址方式 § 3.3 80x86的指令系统 § 3.4 80x86的机器语言指令概况 基本概念—指令系统 每一种计算机都有一组指令集供用户使用,这组指令集称为该计算机的指令系统。指令集中的每条指令在汇编语言中都是用助记符来表示的。 基本概念—指令系统的要求 完备性 有效性 规整性(对称性和均齐性) 兼容性 基本概念—指令的构成 指令由操作码和操作数两部分组成 操作码说明计算机要执行哪种操作,如传送、运算、移位、跳转等操作,它是指令中不可缺少的组成部分 操作数是指令执行的参与者,即各种操作的对象 有些指令不需要操作数,通常的指令都有一个或两个操作数,也有个别指令有3个甚至4个操作数 基本概念—指令在机器中的表示 在机器中,指令的操作码、操作数都用二进制代码表示。——机器指令。 基本概念—8086指令的基本格式 操作码 [目的操作数][,源操作数][;注释] 基本概念—8086指令的基本格式 每种指令的操作码: 用一个唯一的助记符表示(指令功能的英文缩写) 对应着机器指令的一个二进制编码 指令中的操作数: 可以是一个具体的数值 可以是存放数据的寄存器 或指明数据在主存位置的存储器地址 基本概念—寻址方式 所谓寻址就是寻找操作数的地址。 指令中的操作数可能直接给出,也可能放在寄存器里,也可能放在存储器中。 所以在指令的执行过程中,为了取得操作数,既可能要访问寄存器又可能访问存储单元。 寻址方式 寻址的各种方法。 § 3.1 80x86的寻址方式 一、与数据有关的寻址方式 1.立即(数)寻址 指令中的操作数直接存放在机器代码中,紧跟在操作码之后(操作数作为指令的一部分存放在操作码之后的主存单元中) 这种操作数被称为立即数imm 它可以是8位数值i8(00H~FFH) 也可以是16位数值i16(0000H~FFFFH) 立即数寻址方式常用来给R/M赋值 立即数只能用于源操作数 立即数寻址指令 MOV AL,05H ;AL←05 MOV AX,0102H ;AX←0102H 2. 寄存器寻址 操作数存放在CPU的内部寄存器reg中,可以是: 8位寄存器: AH、AL、BH、BL、CH、CL、DH、DL 16位寄存器: AX、BX、CX、DX、SI、DI、BP、SP 4个段寄存器seg: CS、DS、SS、ES MOV BX,AX ;BX←AX 存储器操作数的寻址 当操作数存放在内存中时,寻找操作数归结为如何确定存储单元的地址 逻辑地址 段基值:偏移量 默认段的选择规则 3. 直接寻址 在指令中直接给出存储器偏移地址 操作数的16位偏移量直接包含在指令中,与操作码一起放在代码段中 用符号表示的位移量 MOV BX,VAR ← → MOV BX,DS:VAR ;表示将用符号VAR表示的字单元的内容→ AX ;不声明段则默认为数据段,指明段寄存器则可实现段跨越 用常数表示的位移量 MOV AX,DS:[2000H] ;表示将数据段偏移2000H字节的字单元的内容→ AX 直接寻址 MOV EAX,DATA; DATA为符号地址,存放32位操作数 注:不支持从存储器到存储器的直接传递 MOV [3000H],[2000H] × 4. 寄存器间接寻址 有效地址存放在寄存器中,如BX、BP、SI、DI 所使用的寄存器相当于地址指针,当修改其内容后可指向不同的存储单元 书写时用[]括住寄存器名,以区别于寄存器寻址 若以BP,ESP,EBP间址,操作数默认在栈段SS;若以其他寄存器的默认段(BX、SI、DI间址),操作数默认在数据段DS;使用段超越前缀改变段 4. 寄存器间接寻址 MOV AX,[SI] ← → MOV AX, DS:[SI] MOV CL,[BX] ← → MOV CL, DS:[BX] MOV BL,[BP] ← → MOV BL, SS:[BP] 5.寄存器相对寻址方式 直接变址寻址,基址寻址,变址寻址 有效地址是寄存器内容与有符号8位或16位位移量之和,寄存器可以是BX、BP或SI、DI EA = BX/BP 或 SI/DI +0/8/16位位移量 5.寄存器相对寻址方式 MOV AX,10H[SI] ← → MOV AX,DS:10H[SI] MOV AX,ARRAY[BX] ← → MOV AX,DS:ARRAY[BX] MOV TABLE[DI],AL ← → MOV DS:TABLE[DI],AL MOV TABZ[BP],BL ← → MOV S

文档评论(0)

zilaiye + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档