- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
4指令系统和习题
第四章 8086/8088的指令系统; 计算机的指令一般由操作码和操作数组成,操作码规定了指令的功能;而操作数则规定了指令操作的对象。操作数可以以立即数的形式存放在指令中,但在大多数情况下,操作数是以地址的形式存放在指令(指示操作数在哪儿)。用于说明操作数所在地址的方法称为寻址方式。; 操作数(8位或16的常数)直接包含在指令中,紧跟在操作码后面,与操作码一起放在代码段区域中。操作数im既可是8位的,也可是16位的。; 操作数的有效地址EA是指令的一部分,它与操作码一起放在代码段区域中。 操作数的物理地址为数据段寄存器DS加上16位地址偏移量。;操作数在存储单元中。操作数的有效地址EA在指令码所指定的寄存器中。可作为间址的寄存器有SI、DI、BX、BP,
若:
1、操作数在数据段DS中:则以寄存器BX、SI或DI间接寻址。
2、操作数在堆栈段中:则以寄存器BP间接寻址。; 操作数在存储单元中。操作数的有效地址是以指令指定的寄存器内容加上指令中给定的8位或16位位移量。; 操作数在存储单元中。操作数的有效地址是一个基址寄存器(BX或BP)和一个变址寄存器(SI或DI)的内容之和,两个寄存器均由指令指定。一般由基址寄存器决定所使用的段寄存器。; 操作数在存储单元中。操作数的有效地址是基址寄存器(BX或BP)内容加上变址寄存器(SI或DI)的内容、再加上指令中指定的8位或16位位移量。一般由基址寄存器决定所使用的段寄存器。;* 立即数可以出现在方括号内,表示直接地址;;2、段超越: 在8088系统中,数据通常在数据段中,但若需要,数据也可存放在码段,堆栈段以及附加段中,这种情况就是段超越。应用时,需在指令中加以说明。;3、其它寻址方式;4-2 8086的指令系统;2、堆栈操作指令;? 出栈指令 POP OPRD;3、交换指令;(二)累加器专用传送指令1、输入指令 IN;2、输出指令 OUT;3、换码指令 XLAT (查表指令);(三)地址-目的传送指令;2、LDS将双字指针送指令指定的寄存器和DS指令;3、LES将双字指针送到寄存器和ES指令;(四)标志寄存器传送指令;3、PUSHF 标志入栈指令; 8088指令系统提供了加、减、乘、除四种基本运算指令,可处理无符号或带符号的8位或16位二进制数的算术运算(带符号数是用补码表示)。还提供了各种调整操作指令,故可进行压缩的或非压缩的十进制数的算术运算。绝大部分算术运算指令都影响状态标志位。;执行指令 ADD AX,CX ;(AX)=5389H ,CF=1 ADC DX,BX ;(DX)=1128H ,CF=0 ;4、AAA 未组合BCD码加法调整指令 ;例:求两个多字节无符号数之和。加数在DATA1开始的单元中,被加数在DATA2开始的单元中,字节长度为5,和存放在DATA2中。;
(二)减法指令;例1:设(DX)= 3A49H,CF =1 执行指令 SBB DX,1850H 执行结果 (DX)= 21F8H,CF=0 ; 比较指令主要用在希望比较两个数之间的关系,而又不破坏原操作数的场合。即两者是否相等,或两个中哪一个大。一般有下列几种情况:;6、AAS 未组合BCD码减法调整指令 ;例:在BLOCK开始的内存单元中有100个16位带符号数,请寻找出最大值并送MAX单元。;(三)乘法指令;功能:对两个无符号数进行除法运算。源操作数可以是字节或字。;4、CWD 把字转换成双字指令 指令执行后,不影响标志位;三、逻辑运算指令;CF;? SHR 逻辑右移指令;指令执行后对标志位的影响:
? 标志位CF 总是为目的操作数最后被移出的那一位的值。
? 标志位OF:只有当CNT= 1时才有效,用以表示移位前后符号位是否改变,若改变,OF = 1 , 否则OF = 0。即对左移指令(SAL/ SHL),若移位后最高有效位与标志位CF 不相等,则OF = 1,否则OF = 0。而对右移指令,若移位后,操作数的最高有效位与次高位不同,则OF = 1,否则OF = 0。;3、循环移位指令;(二) 双操作数操作指令;
3、OR “逻辑或”指令;四、串操作指令;1、MOVS串传送指令 (不影响标志位);2、CMPS 串比较指令;例:在自KA和KB单元开始各有一个由30个字符组成的字符串,检查这两个字符串是否相等,并在GG单元中建立一个标志(相等为00,不等为FFH);3、SCAS 串
文档评论(0)