- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
(二) 处理器暂停指令 使CPU 进入暂停状态,当有复位信号时,或有中断请求时,脱离暂停状态。 (三〕ESC 交权指令: 处理器把控制权交给8087协处理器,以提高系统的数运算速度。 (四)WAIT 处理器等待指令:使CPU进入等待状态,不作任何操作。TEST引脚的低电平使CPU退出等待状态。 (五)LOCK 总线锁定指令:它是一种前缀,可加在任何指令前面,用来维持总线的锁存信号,直到该指令执行完为止,使别的处理器不能控制总线。 1、 HLT 2、NOP 空操作指令:单字节三周期指令。 七、软件延时程序 例3-96 MOV BX,N1 ;4×1 CNT1 :MOV CX,N2 ;4×N1 CNT2 : LOOP CNT2 ;(17×N2-12)×N1 DEC BX ;2×N1 JNZ CNT1 ;16×N1-12 RET 上面程序执行所需要的总的时钟周期数CT为: CT=时钟×次数=17×N1×N2+10×N1-8 指令执行后对标志位的影响: ? 标志位CF 总是为目的操作数最后被移出的那一位的值。 ? 标志位OF:只有当CNT= 1时才有效,用以表示移位前后符号位是否改变,若改变,OF = 1 , 否则OF = 0。即对左移指令(SAL/ SHL),若移位后最高有效位与标志位CF 不相等,则OF = 1,否则OF = 0。而对右移指令,若移位后,操作数的最高有效位与次高位不同,则OF = 1,否则OF = 0。 ? 标志位ZF、SF 根据指令执行后目的操作数的状态来决定,PF 只有当目的操作数在AL中时才有效。标志位AF 未定义。 例1:设(BL)= 5AH, 执行指令 SHL BL,1 后 (BL)= 0B4H,标志位CF = 0,OF = 1 例2:设(DS)= 2800H,(DI)= 180AH,(2980AH)= 1256H 执行 MOV CL,02H SAR [ DI ],CL 后 (2980AH)= 0495H,CF = 1,ZF = 0,SF = 0 3、循环移位指令 ? ROL循环左移指令 指令格式:ROL OPRD,CNT MSB ?? LSB 操作 CF MSB ?? LSB ? ROR循环右移指令 指令格式:ROR OPRD,CNT 操作 CF ? RCL带进位循环左移指令 指令格式:RCL OPRD,CNT 操作 MSB ?? LSB CF ? ? ? RCR带进位循环右移指令 指令格式:RCR OPRD,CNT 操作 MSB ?? LSB CF ? ? 四条指令都按指令中CNT规定的移位次数进行循环移位,移位后的结果仍送回目的操作数。OPRD可以是8/ 16位的寄存器或内存操作数,移位次数可以是1,也可以由CL寄存器的值指定。 标志位CF的值由最后一次被移出的值决定;OF位仅在CNT为1时才有效,在移位后操作数的最高有效位(符号位)发生变化时,则OF=1,否则OF置0. 例:设CF=1, (AL) =0B4H,若执行指令ROL AL, 1 ; 则(AL) = 69H, CF = 1, OF = 1 若执行指令RCR AL , 1 ; 则(AL) = 0DAH , CF =0, OF = 0 (二) 双操作数操作指令 该类指令能对两个操作数按位进行与、或、异或及测试操作。目的操作数可以是寄存器或内存操作数;源操作数可以是寄存器或内存操作数,还可以是立即数。 1、AND逻辑与指令 格式:AND OPRD1,OPRD2 功能:对两个操作数进行按位“逻辑与”操作,结果送回目的操作数。主要用于使操作数的某些位保持不变(和‘1’相与), 而使某些位清0(和‘0’相与) 例: 设(AX) = 3538H , 执行指令 AND AX,0F0FH 后 ; (AX) =0508H 2、TEST 测试指令 格式:TEST OPRD1,OPRD2 功能:对两个操作数进行“逻辑与”操作, 但不回送结果, 即指令执行后两操作数不变。该指令常用在要检测某些条件是否满足,但又不希望改变原有操作数的情况下。紧跟在这条指令后面的往往是一条件转移指令,根据测试结果产生分支,转向不同的处理程序。 例如,要判断在BX寄存器中16位数的最高位是否为‘ 1’,
文档评论(0)