指令系统(7讲).pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
指令系统(7讲),指令系统,计算机指令系统,8086指令系统,计算机指令系统是指,cpu的指令系统又称为,精简指令系统,单片机指令系统,富远版的指令系统,cpu的指令系统

2. 减法指令 (2) 考虑借位的减法指令SBB (3) 减1指令DEC (4) 求补指令NEG (5) 比较指令CMP 根据标志位来判断比较的结果 1)根据ZF判断两个数是否相等。若ZF=1,则两数相等。 2)若两个数不相等,则分两种情况考虑: ①比较的是两个无符号数 若CF=0,则dest>src; 若CF=1,则dest<src。 ②比较的是两个有符号数 若OF⊕SF=0(两标志位同状态),则dest>src; 若OF⊕SF=1(两标志位异状态),则dest<src。 (6)压缩BCD码减法调整指令DAS 指令格式: DAS 指令功能: 对AL中两个压缩的BCD码相减后的结果进行调整。(类似DAA) (7)非压缩BCD码减法调整指令AAS 指令格式: AAS 指令功能: 对AL中非压缩BCD码相减的结果进行调整。(类似AAA) 3. 乘法指令 (2) 有符号数乘法指令IMUL 对AX中由两个非压缩BCD码相乘的结果进行调整。 隐含的操作寄存器为AL和AH; AAM跟在MUL指令之后使用; 影响标志位PF、SF、ZF,其它无定义; 用AAM还可实现≤99的二-十进制转换。 4. 除法指令 进行除法时:16位÷8位→8位商 32位÷16位→16位商 对被除数、商及余数存放有如下规定: 被除数 商 余数 字节除法 AX AL AH 字除法 DX,AX AX DX (1) 无符号数除法指令DIV (2) 有符号数除法指令IDIV 格式: IDIV src 操作与DIV类似。商及余数均为有符号数,且余数符号总是与被除数符号相同。 注意: 对于DIV/IDIV指令 AX(DX,AX)为隐含的被除数寄存器。 AL(AX)为隐含的商寄存器。 AH(DX)为隐含的余数寄存器。 src不能为立即数。 对所有条件标志位均无定义。 除法运算要求被除数字长是除数字长的两倍,若不满足则需对被除数进行扩展,否则产生错误。 对于无符号数除法扩展,只需将AH或DX清零即可。 对有符号数而言,则是符号位的扩展。可使用前面介绍过的符号扩展指令CBW和CWD 例: 写出34H÷25H的程序段。 MOV AL,34H MOV BL,25H CBW ; AL的符号扩展到AH IDIV BL ; 0034H÷25H,结果为 ; (AH)=0FH, (AL)=01H (3) 除法的十进制调正指令AAD 对非压缩BCD除法运算进行调整。 隐含的操作寄存器为AH,AL; AAD要在DIV指令之前使用; 影响标志位PF、SF、ZF,其它无定义; 用AAD还可实现≤99的十-二进制转换。 例1:按十进制乘法计算7×8=? 程序段如下: MOV AL,07H ;(AL)=07H MOV CL,08H ;(CL)=08H MUL CL ;(AX)=0038H AAM ;(AH)=05H,(AL)=06H 所得结果为非压缩的BCD码。 例2:把3AH转换成等值的十进制数(非压缩BCD码)。 MOV AL,3AH ;58 AAM ;(AH)=05H,(AL)=08H 例3:按十进制除法计算55÷7=? 程序段如下: MOV AX, 0505H ;(AX)=55非压缩BCD MOV CL, 07H ;(CL)= 7 AAD ;(AX)=0037H DIV CL ;(AH)=6, (AL)=7 所得结果为非压缩的BCD码(商7余6)。 例4:把十进制数73转换成等值的二进制数。 MOV AX, 0703H ;(AX)= 73非压缩BCD AAD ;(AX)= 0049H *5.BCD码运算的十进制调整指令 专用于对BCD码运算的结果进行调整; 包括:AAA、DAA、AAS、DAS、AAM、AAD; 均为隐含寻址,隐含的操作数为AL和AH; 为何要对BCD码的运算结果进行调整? BCD码本质上是十进制数,即应遵循逢十进一的规则。而计算机是按二进制(十六进制)进行运算,并未按十进制规则进行运算。 1)加法的十进制调整指令 (1)非压缩BCD码加法调整AAA 本指令对在AL中的由两个未组合的BCD码相加

文档评论(0)

vr7743178 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档