- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
微机原理与接口技术 第3章 指令系统 Ⅱ 上课啦 第二部分 8086/8088指令系统 二. 算术运算指令[上](Arithmetic) 功能:加、减、乘、除;BCD码表示的十进制数算术运算 (一)加法指令(Arithmetic) (二)减法指令(Subtraction) (三)乘法指令(Multiplication) (四)除法指令(Division) (五)BCD码指令 (六)扩展指令 特点: ? 多数指令要影响FR,不同指令影响不同 (1) 加、减法指令影响SF,ZF,AF,PF,CF,OF; (2) 加1和减1指令不影响CF; (3) 乘法指令影响CF,OF; (4) 除法指令使大部分标志位的状态不确定; (5) BCD码调整指令对标志位的影响不同; (6) 转换指令对标志位无影响 ? 双操作数指令除源数可为立即数外,其余必须有一个为寄存器操作数;单操作数指令不能为立即数。 ? 运算有带符号数与无符号数。 ? 都可以对字节、字进行算术运算(二进制运算和十进制运算),个别可以运算双字。 (一)加法指令 1、 ADD (Addition) 2、 ADC (Add with carry) 3、 INC (Increment by 1) 例1: 设(AX)=4H,(BX)=200H,(DX)=6H, (DI)=500H (DS: 502)=2H 则 ADD AX, BX ;执行后(AX)=204H ADD DX, 2[DI] ;语句执行后(DX)=8H 1、不带进位加法指令ADD 格式: ADD dest , src 功能: (dest) ?(src)+(dest) ①源数与目的数相加 ②和送入目的操作数 ③根据和设置FR中标志位 例2 MOV AL, 7EH ;(AL)=7EH MOV BL, 5BH ;(BL)=5BH ADD AL, BL ;(AL)=7EH+5BH=D9H 影响标志位的情况: SF=1 , 结果最高位=1 ZF=0 ,结果不等于0 AF=1 ,D3 位向D4 有进位 PF=0 ,“1”的个数为奇数 CF=0 ,无进位 OF=1 ,和超过+127 注解: (1)ADD可以完成字、字节相加,源数和目标数必须同为无符号数或者同为有符号数。 (2)dest可以为Reg、Mem src可以为Im、Reg、Mem,不能同时为Mem。 有下列合法5种格式 ADD R, R ;通用寄存器之间相加 ADD R, Im ;通用寄存器与立即数之间相加 ADD M, Im ;内存数与立即数相加 ADD M, R ;通用寄存器与内存数之间相加 ADD R, M ;内存数与通用寄存器之间相加 (3)SegR内容不参与加减乘除运算 判断下列语句合法否? ADD AX,CL ADD DS,BX ADD [SI],[1000H] ADD AH,DATA-BYTE ×,bit不匹配 ×,SegR不参与 ×,不能M—M √ (4)指令影响标志位的情况: OF=1:8位带符号数相加,和超出范围(-128到+127) 16位带符号数相加,和超出范围(-32768到+32767); OF标志可用来表示有符号数的溢出,有符号数的溢出是一种出错,在运算过程中应当避免。 CF=1:8位无符号数相加,和超过255, 16位无符号数相加,和超过65535。 CF标志可用来表示无符号数的溢出。 其他条件标志(SF,AF,PF,ZF)根据定义设定。 (1) 带符号数和无符号数都不溢出 。 以8位数加法为例,说明“溢出”对FR中CF、OF标志位的影响 (2) 无符号数溢出 二进制数 看作无符号数 看作带符号数 0 0 0 0 0 1 1 1 1 1 1 1 1 0 1 1 + 0 0 0 0 0 0 1 0 7 251 + 258 + 7 - 5 + + 2 相 加 标志 CF=1,OF=0 CF=1 OF=0 溢出 无符号数溢出 溢出 结果应为2,错 不溢出 异号数相加 不可能有溢出 CF=1 以8位数加法为例,说明“溢出”对FR中CF、OF标志位的影响 (3) 带符号数溢出 以8位数加法为例,说明“溢出”对FR中CF、OF标志位的影响 (4) 带符号数和无符号数都溢出 以8位
文档评论(0)