05 算术指令、逻辑指令和串处理指令.pptxVIP

05 算术指令、逻辑指令和串处理指令.pptx

  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文档。上传文档
查看更多
IBM—PC汇编语言 程序设计(第2版);算术运算指令:反映CPU计算能力的一组指令,也是编程时常使用的一组指令。 包括:加、减、乘、除及其相关的辅助指令(共21条指令 )。 加法指令?ADD、ADC、INC、XADD(交换并相加) ; 减法指令?SUB、SBB、DEC、NEG、CMP、 CMPXCHG(比较并交换) 、CMPXCHG8B(比较并交换8字节) ; 乘法指令?MUL、IMUL; 除法指令?DIV、IDIV; 十进制调整指令?两类6条: ⑴.压缩BCD码调整指令:加法调整(DAA)、减法调整(DAS) ; ⑵.非压缩BCD码调整指令:①.ASCⅡ加调整(AAA)、ASCⅡ减调整(AAS)、 ②.ASCⅡ乘调整(AAM)、ASCⅡ除调整(AAD); 算术运算指令的操作数可以是8位、16位。当存储单元是该类指令的操作数时,该操作数的寻址方式可以是任意一种存储单元寻址方式。寻址方式如下: ⑴.单操作数时:不能立即寻址,其他寻址均可; ⑵.双操作数除原操作数为立即数以外,必须至少有一个是寄存器寻址;;标志寄存器FLAGS的介绍;加/减法指令对6个状态标志的定义 ⑴.进位标志CF(Carry Flag)?当运算结果的最高有效位有进位(加法)或借位(减法)时,进位标志置1,即CF=1;否则CF=0。 例如:3AH+7CH = B6H,没有进位:CF=0;9CH-7DH = 1FH,没有借位:CF=0; 0BAH+7CH= (1)36H,有进位:CF=1;12H-21H = (1)F1H,有借位:CF=1; ⑵.奇偶标志PF(Parity Flag)?当加减运算结果最低字节中“1”的个数为零或偶数时,PF=1;否则PF=0。 例如:013AH+127CH=0001001110110110B,结果最低字节中有5个1,是奇数:PF=0 213AH-1277H=0000111011000011B,结果最低字节中有4个1,是奇数:PF=1 注意:无论是多少位操作,PF标志仅反映最低8位中“1”的个数是否为偶数。 ⑶.辅助进位标志AF(Auxiliary Carry Flag)?运算时D3位(最低半字节)有进位或借位时,AF=1;否则AF=0。 例如:3AH+7CH=B6H,D3有进位:AF=1; ,D3无借位:AF=0; 注意:AF标志主要由处理器内部使用,用户不必关心;;⑷.零标志ZF(Zero Flag)?若加减运算结果为0,则ZF=1,否则ZF=0;即:ZF表示加减运算结果是否为0; 例如:3AH+7CH=B6H,结果不是零:ZF=0 而 84H+7CH=(1)00H,结果是零:ZF=1; 8AH-7CH=0EH,结果不是零??ZF=0 而 84H+84H=00H,结果是零:ZF=1; ⑸.符号标志SF(Sign Flag)?加减运算结果最高位为1,则SF=1;否则SF=0。 例如: 3AH + 7CH=B6H,最高位D7=1:SF = 1 86H + 7CH=(1)00H,最高位D7=0:SF = 0 注意:有符号数利用最高有效位表示数据的符号。所以,最高有效位就是符号标志的状态。 ⑹.溢出标志OF(Overflow Flag)?加减法定义不同: 加法定义:两操作数最高位相同,而结果最高位与其相反是OF=1,否则OF=0; 减法定义:两操作数最高位不同,而结果的最高位与减数的最高位相同,则 OF=1,否则OF=0; 例如:3AH + 7CH = B6H,OF = 1;AAH + 7CH =(1)26H,OF = 0; 3AH - 7CH =(1)BEH,OF = 0;AAH - 7CH =2EH,OF = 1; 问题:什么是溢出?溢出和进位有什么区别?如何判断是否溢出?;举例:n=8 bit 带符号数(-128~127),无符号数(0~255)超出此范围则溢出;(一)、加法指令 ;【例1】加1指令: 例如: INC DWORD PTR job //(job)←(job)+1;可能溢出 INC AL //(AL)←(AL)+1;可能溢出 【例2】双字加法运算,设目的操作数存放在DX和AX寄存器中,其中DX放高位字,源操作数存放在BX和CX寄存器中,其中BX放高位字,指令执行前: (DX)=0020H,(AX)=0F365H,(BX)=0005H, (CX)=0E024H。 AD

文档评论(0)

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

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

1亿VIP精品文档

相关文档