第3章指令系统与汇编语言程序设计PPT.ppt

  1. 1、本文档共52页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第3章指令系统与汇编语言程序设计PPT

3.1 寻址方式 3.2 指令系统 3.3 汇编语言程序的汇编与调试 3.4 汇编语言程序设计举例 3.5 计算机中的数据编码;3.1 寻址方式;一、寻址方式 见动画五—寻址方式。;3.2 指令系统 ;描述指令的一些符号的意义: ;例1 分析下列指令的寻址方式以及指令执行后存储单元和寄存 器的内容。 MOV A, # 20H ; 目的操作数采用寄存器寻址,A=20H MOV 32H, # 23H ; 目的操作数采用直接寻址,(32H)=23H MOV R4, # 2FH ; 目的操作数采用寄存器寻址,R4=2FH MOV @ R0, # 5AH ; 目的操作数采用寄存器间接寻址, (R0)=5AH MOV DPTR, # 203FH ; 目的操作数采用寄存器寻址, DPTR=203FH ;例2 分析指令的寻址方式和执行结果 MOV P2,R2; 目的操作数采用直接寻址,源操作数为寄存器寻址; P2=R2,该指令等价于MOV 0A0H,R2 MOV 2FH,30H; 两个操作数均采用直接寻址,(2FH)= (30H) MOV 20H,@ R1; 目的操作数为直接寻址,源操作数为寄存器间接寻址,执行 结果:(20H)= (R1);例3 分析下列指令的寻址方式和执行结果 MOV A,R5 ; 两操作数均采用寄存器寻址,A=R5 MOV A,0F0H ; 原操作数为直接寻址,A=(0F0H) MOV A,@ R1 ; 源操作数为寄存器间接寻址,A=(R1); 这类指令的操作码助记符为“MOVX”,对外部RAM单元只 能使用间接寻址方式,即可以使用DPTR和Ri作间址寄存器。 MOVX A,@ DPTR ;A←(DPTR) MOVX @ DPTR,A ;(DPTR)←A MOVX A,@ Ri ;A ←(Ri) MOVX @ Ri,A ;(Ri)←A 例3.4 已知DPTR=2000H,片外RAM (2000H)=05H, R1=0F0H,片外RAM (0F0H)=0A0H。 MOVX A,@ DPTR ;指令执行后,A=05H MOVX @ R1,A ;指令执行后,片外RAM(0F0H)=05H ; 这类指令助记符为“MOVC”,共两条指令。 MOVC A,@A+DPTR ;A←(A+DPTR) MOVC A,@A+PC ;A←(A+PC) 例3.5 把累加器A中的十六进制数字00H~0FH转换成ASCII码。 INC A ;调整偏移量(数据表的首地址与MOVC指令间隔1个单元) MOVC A,@ A + PC ;查表取数 RET ;子程序返回 DB 30H,31H,32H,33H,34H ;在程序存储器中顺序存放 DB 35H,36H,37H,38H,39H ;0~F的ASCII码 DB 41H,42H,43H,44H,45H,46H 如果累加器A=0FH,则执行INC A 后,A=10H,程序存储器取出MOVC指令后,PC = 2001H,则A + PC=2011H,于是执行 MOVC 指令后A=(2011H)=46H,即将累加器A中十六进制数字F 转换成相应的ASCII 码46H。 ;(1)字节交换指令;(1)进栈指令 PUSH direct ;SP←SP + 1,(SP)←(direct) (2)出栈指令 POP direct ; (direct)←(SP),SP←SP – 1 例3.8 已知SP = 3AH,DPTR= 1234H,则 PUSH DPL ;SP←SP + 1=3BH,(3BH)=34H POP DPH ;SP←SP + 1=3CH,(3CH)=12H 执行指令后,SP=3CH,(3CH)=12H,(3BH)=34H;

文档评论(0)

djdjix + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档