51单片机汇编语言指令教程(校对版)
51单片机汇编语言教程:11课单片机算术运算指令

51 实验板推荐(点击下面的图片可以进入下载资料链接)
ห้องสมุดไป่ตู้HJ-1G
HJ-3G
推荐使用慧净 51 实验板。推荐 51 学习网 淘宝网:/
除法一般会出现小数但计算机中可没法直接表达小数它用的是我们小学生还没接触到小数时用的商和余数的概念如135其商是2余数是除了以后商放在a中余数放在b中
51 单片机汇编语言教程-慧净电子会员收集整理 (全部 28 课)
51 单片机汇编语言教程:第 11 课-单片机算术运算指令
(基于 HJ-1G、HJ-3G 实验板) 不带进位位的单片机加法指令 ADD A,#DATA ;例:ADD A,#10H ADD A,direct ;例:ADD A,10H ADD A,Rn ;例:ADD A,R7 ADD A,@Ri ;例:ADD A,@R0 用途:将 A 中的值与其后面的值相加,最终结果否是回到 A 中。 例:MOV A,#30H ADD A,#10H 则执行完本条指令后,A 中的值为 40H。 下面的题目自行练习 MOV 34H,#10H MOV R0,#13H MOV A,34H ADD A,R0 MOV R1,#34H ADD A,@R1 带进位位的加法指令 ADDC A,Rn ADDC A,direct ADDC A,@Ri ADDC A,#data 用途:将 A 中的值和其后面的值相加,并且加上进位位 C 中的值。 说明:由于 51 单片机是一种 8 位机,所以只能做 8 位的数学运算,但 8 位运算的范围只有 0-255,这在实际工作中是不够的,因此就要进行扩展,一般是将 2 个 8 位的数学运算合起 来,成为一个 16 位的运算,这样,能表达的数的范围就能达到 0-65535。如何合并呢?其 实很简单,让我们看一个 10 进制数的例程: 66+78。 这两个数相加,我们根本不在意这的过程,但事实上我们是这样做的:先做 6+8(低位), 然后再做 6+7,这是高位。做了两次加法,只是我们做的时候并没有刻意分成两次加法来做 罢了,或者说我们并没有意识到我们做了两次加法。之所以要分成两次来做,是因为这两个 数超过了一位数所能表达的范置(0-9)。 在做低位时产生了进位,我们做的时候是在适当的位置点一下,然后在做高位加法是将这一 点加进去。那么计算机中做 16 位加法时同样如此,先做低 8 位的,如果两数相加产生了进 位,也要“点一下”做个标记,这个标记就是进位位 C,在 PSW 中。在进行高位加法是将这 个 C 加进去。例:1067H+10A0H,先做 67H+A0H=107H,而 107H 显然超过了 0FFH,因此 最终保存在 A 中的是 7,而 1 则到了 PSW 中的 CY 位了,换言之,CY 就相当于是 100H。 然后再做 10H+10H+CY,结果是 21H,所以最终的结果是 2107H。 带借位的单片机减法指令 SUBB A,Rn SUBB A,direct SUBB A,@Ri SUBB A,#data
51单片机汇编语言教程

例:写出以下单片机程序的运行结果
MOV 30H,#12
MOV 31H,#23
PUSH 30H
PUSH 31H
POP 30H
POP 31H
结果是30H中的值变为23,而31H中的值则变为12。也就两者进行了数据交换。从这个例程能看出:使用堆栈时,入栈的书写次序和出栈的书写次序必须相反,才能保证数据被送回原位,不然就要出错了。
标号的真实含义:从这个地方也能看到另一个问题,我们使用了标号来替代具体的单元地址。事实上,标号的真实含义就是地址数值。在这里它代表了,0,1,4,9,16,25这几个数据在ROM中存放的起点位置。而在以前我们学过的如LCALL DELAY单片机指令中,DELAY 则代表了以DELAY为标号的那段程序在ROM中存放的起始地址。事实上,CPU正是通过这个地址才找到这段程序的。
能通过以下的例程再来看一看标号的含义:
MOV DPTR,#100H
MOV A,R0
MOVC A,@A+DPTR
ORG 0100H.
DB 0,1,4,9,16,25
如果R0中的值为2,则最终地址为100H+2为102H,到102H单元中找到的是4。这个能看懂了吧?
那为什么不这样写程序,要用标号呢?不是增加疑惑吗?
这有什么意义呢?ACC中的值本来就是100,B中的值本来就是20,是的,在本例中,的确没有意义,但在实际工作中,则在PUSH B后一般要执行其他指令,而且这些指令会把A中的值,B中的值改掉,所以在程序的结束,如果我们要把A和B中的值恢复原值,那么这些指令就有意义了。
还有一个问题,如果我不用堆栈,比如说在PUSH ACC指令处用MOV 60H,A,在PUSH B处用指令MOV 61H,B,然后用MOV A,60H,MOV B,61H来替代两条POP指令,不是也一样吗?是的,从结果上看是一样的,但是从过程看是不一样的,PUSH和POP指令都是单字节,单周期指令,而MOV指令则是双字节,双周期指令。更何况,堆栈的作用不止于此,所以一般的计算机上都设有堆栈,单片机也是一样,而我们在编写子程序,需要保存数据时,常常也不采用后面的办法,而是用堆栈的办法来实现。
51单片机汇编语言教程:13课单片机逻辑与或异或指令详解

51单片机汇编语言教程:第13课-单片机逻辑与或异或指令详解结果11111001而所有的或指令,就是将与指仿中的ANL换成ORL,而异或指令则是将ANL换成XRL。
即或指令:ORL A,Rn;A和Rn中的值按位'或',结果送入A中ORL A,direct;A和与间址寻址单元@Ri中的值按位'或',结果送入A中ORL A,#data;A和立direct中的值按位'或',结果送入A中ORL A,@Ri;A和即数data按位'或',结果送入A中ORL direct,A;direct中值和A中的值按位'或',结果送入direct中ORL direct,#data;direct中的值和立即数data按位'或',结果送入direct中。
异或指令:XRL A,Rn;A和Rn中的值按位'异或',结果送入A中XRL A,direct;A和direct中的值按位'异或',结果送入A中XRL A,@Ri;A和间址寻址单元@Ri中的值按位'异或',结果送入A中XRL A,#data;A和立即数data按位'异或',结果送入A中XRL direct,A;direct中值和A中的值按位'异或',结果送入direct中XRL direct,#data;direct中的值和立即数data按位'异或',结果送入direct中。
练习:MOV A,#24HMOV R0,#37HORL A,R0XRL A,#29HMOV35H,#10HORL35H,#29HMOV R0,#35HANL A,@R0四、控制转移类指令无条件转移类指令短转移类指令AJMP addr11长转移类指令LJMP addr16相对转移指令SJMP rel上面的三条指令,如果要仔细分析的话,区别较大,但开始学习时,可不理会这么多,统统理解成:JMP标号,也就是跳转到一个标号处。
51单片机汇编语言指令教程(校对版)

03
02
01
00
返回前一次
2.2.3立即寻址
指令本身直接含有所需要的8位或16位的操作数。
将此数称为“立即数”(使用#标明)。如:
MOV A,#30H
;将(8位)立即数送累加器A
MOV DPTR,#2000H ;16位立即数送DPTR积存器
【注意】:MOV A,#30H MOV A,30H 两者的区别。 立即数寻址的指令长度为2或3个字节。
5,位操作指令:位传送、位置位、位运算和位控制转移等 操作。 【 特点】:按位操作而不是按字节的操作。位控转移的判 断不是检测某一个字节而是对某一个位进行检测并决定是 否进行程序转移。 这类指令基本不影响PSW的内容。
2.2 寻址方式
在指令的操作数位置上,用于表征、寻找操作数的方式定义 为“寻址方式”。
3,间址方式的指令不能访问SFR中的单元。如下面的程序 是错误的: MOV R1,#80H MOV A,@R1 (因为80H为SFR的物理地址)
MCS-51 片内 、片外 数据存储器示意图
FFH 特殊功能 寄存器 SFR
80H 7FH
通用数据 存储器
00H
片内数据存储器 256B个字节
FFFFH
注意:
片外数据 存储器 64KB
1,访问片内RAM20H存储单元; MOV A,20H
2,访问片外RAM存储单元; MOV R0,#20H MOVX A,@R0
0000H
3,尽管片内与片外的RAM单元 的00H-FFH地址相重叠但由 于指令的不同不会发生地址
混乱。
片外数据存储器 64KB个字节
2.2.5 变址寻址
操作码 OP
操作数或操作数地址 DATA 或 ADDRESS
51单片机汇编语言

累加器减立即数和借位 累加器减直接寻址字节和借位 累加器减 1 寄存器减 1 内部 RAM 减 1 直接寻址字节减 1 累加器乘寄存器 B 累加器除以寄存器 B 累加器与寄存器 累加器与内部 RAM 累加器与立即数 累加器与直接寻址字节 直接寻址字节与累加器 直接寻址字节与立即数 累加器或寄存器 累加器或内部 RAM 累加器或立即数 累加器或直接寻址字节 直接寻址字节或累加器 直接寻址字节或立即数 累加器异或寄存器 累加器异或内部 RAM 累加器异或立即数 累加器异或直接寻址字节 直接寻址字节异或累加器 直接寻址字节异或立即数 累加器左环移位 累加器连进位标志左环移位 累加器右环移位 累加器连进位标志右环移位 累加器高 4 位与低 4 位交换 累加器取反 累加器清零 直接寻址位送 C C 送直接寻址位 C 清零 直接寻址位清零 C 取反 直接寻址位取反 C 置位 直接寻址位置位 C 与直接寻址位 C 与直接寻址位的反 C 或直接寻址位 C 或直接寻址位的反 C 置位转移
5-1
字节数 1 1 1 1 2 2 2 2 3 2 2 2 2 2 3 3 1 1 1 1 1 1 1 1 2 1 2 2 1 1 2 2 1 1 2 2 1 1 2 1 1 1 1 1
振荡周期数 12 12 12 12 12 12 12 12 24 12 24 24 24 24 24 24 24 24 24 24 24 24 12 12 12 12 24 24 12 12 12 12 12 12 12 12 12 12 12 12 24 12 12 12
51 单片机汇编语言
94( ) 95( ) 14 1m 1k 15( ) A4 84 5m 5k 54( ) 55( ) 52( ) 53( )( ) 4m 4k 44( ) 45( ) 42( ) 43( )( ) 6m 6k 64( ) 65( ) 62( ) 63( )( ) 23 33 03 13 C4 F4 E4 A2( ) 92( ) C3 C2( ) B3 B2( ) D3 D2( ) 82( ) B0( ) 72( ) A0( ) 40( )
MCS-51单片机的汇编语言

绝对地址段选择伪指令
CSEG
[AT
address]
DSEG
[AT
address]
ISEG
[AT
address]
BSEG
[AT
address]
XSEG
[AT
address]
分别为程序存储器、内部数据存储器、间接寻址的内部数据存 储器、位寻址区和外部数据存储器的使用指定绝对地址
1.5 通用的转移和调用语句
MCS-51汇编器允许程序员使用通用的转移和调用助记符JMP 与CALL
用来代替SJMP、AJMP、LJMP和ACALL、LCALL
汇编产生的未必是最优化的结果
1.6 条件汇编
将一个软件的多个版本保存在同一组源程序文件中 使用IF、ELSEIF、ELSE、ENDIF IF或ELSEIF后的表达式通常为关系表达式 当IF或ELSEIF后的数值表达式的值非零时,汇编其后的语句组;
1.4 伪指令语句
ORG伪指令
ORG
பைடு நூலகம்
expression
设置汇编计数器的值,指定其后语句的起始地址
伪指令语句
END伪指令
应当是源程序的最后一条语句 通知汇编程序汇编过程应在此结束 汇编器不理会END后面的文件内容
每个程序文件都应以END结束
伪指令语句
EQU和SET伪指令
symbol
单片机原理与应用
MCS-51单片机的汇编语言
INTS SET
IF ELSE ENDIF
INTS = 1 MAIN_START
MAIN_START
NUM1 DATA NUM2 DATA
DSEG AT
STACK: DS
20H
51单片机汇编语言指令教程汇集

51单片机汇编语言指令教程汇集
1.MOV
MOV指令把源操作数的值复制到目的操作数。
格式如下:
MOV dest,src
dest :用于存储源操作数值的目的操作数。
src :用于取源操作数值的源操作数。
MOV指令可以把源操作数的值复制到目的操作数里,其中它的源操作数和目的操作数可以是内存单元,寄存器或立即数。
2.MVI
MVI指令把单字节立即数的值复制到其中一寄存器或内存单元。
格式如下:
MVI dest,data
dest :用于存放单字节立即数值的目的操作数。
data :用于取立即数值的立即数。
MVI指令可以把数据(data)复制到dest所指向的存储单元。
它的目的操作数可以是内存单元或寄存器,源操作数只能是8位立即数。
3.LXI
LXI指令可以把16位数据装载到左边和右边双字节寄存器中。
格式如下:
LXI rp,data
rp :用接受16位数据的双字节寄存器,它可以是BC,DE,HL或SP。
data :用于取16位立即数的立即数。
LXI指令可以把16位立即数data复制到双字节寄存器rp里。
4.LDA
LDA指令可以把存储单元中的数据装载到A寄存器中,格式如下:
LDA addr
addr :用于取存储单元数据值的存储单元地址。
LDA指令可以把存储单元addr中的数据复制到A寄存器中。
5.STA
STA指令可以把A寄存器的值存入指定的存储单元中,格式如下:
STA addr。
51单片机汇编语言教程:15课单片机位操作指令

51 实验板推荐(点击下面的图片可以进入下载资料链接)
HJ-1G
HJ-3G
推荐使用慧净 51 实验板。推荐 51 学习网 淘宝网:/
推荐使用慧净 51 实验板。推荐 51 学习网 淘宝网:/
51 单片机汇编语言教程-慧净电子会员收集整理 (全部 28 课)
位或指令 ORL C,bit ORL C,/bit 这个的功能大家自行分析吧,然后对照上面的例程,编一个验证程序,看看你相得对吗? 位条件转移指令 判 CY 转移指令 JC rel JNC rel 第一条指令的功能是如果 CY 等于1就转移,如果不等于1就次序执行。那么转移到什么地方 去呢?我们能这样理解:JC 标号,如果等于1就转到标号处执行。这条指令我们在上节课中 已讲到,不再重复。 第二条指令则和第一条指令相反,即如果 CY=0就转移,不等于0就次序执行,当然,我们也 同样理解: JNC 标号 判位变量转移指令 JB bit,rel JNB bit,rel 第一条指令是如果指定的 bit 位中的值是1,则转移,不然次序执行。同样,我们能这样理 解这条指令:JB bit,标号 第二条指令请大家先自行分析 下面我们举个例程说明: ORG 0000H LJMP START ORG 30H START:MOV SP,#5FH MOV P1,#0FFH MOV P3,#0FFH L1: JNB P3.2,L2 ;P3.2上接有一只按钮,它按下时,P3.2=0 JNB P3.3,L3 ;P3.3上接有一只按钮,它按下时,P3.3=0 LJM P L1 L2: MOV P1,#00H
推荐使用慧净 51 实验板。推荐 51 学习网 淘宝网:/
51 单片机汇编语言教程-慧净电子会员收集整理 (全部 28 课)
MOV P1.0,CY ;将 P1.0的状态送给 CY。 位修正指令 位清0指令 CLR C ;使 CY=0 CLR bit ;使指令的位地址等于0。例:CLR P1.0 ;即使 P1.0变为0 位置1指令 SETB C ;使 CY=1 SETB bit ;使指定的位地址等于1。例:SETB P1.0 ;使 P.0变为1 位取反指令 CPL C ;使 CY 等于原来的相反的值,由1变为0,由0变为1。 CPL bit ;使指定的位的值等于原来相反的值,由0变为1,由1变为0。 例:CPL P1.0 以我们做过的实验为例,如果原来灯是亮的,则执行本指令后灯灭,反之原来灯是灭的,执 行本指令后灯亮。 位逻辑运算指令 位与指令 ANL C,bit ;CY 与指定的位地址的值相与,结果送回 CY ANL C,/bit ;先将指定的位地址中的值取出后取反,再和 CY 相与,结果送回 CY,但注意, 指定的位地址中的值本身并不发生变化。 例:ANL C,/P1.0 设执行本指令前,CY=1,P1.0等于1(灯灭),则执行完本指令后 CY=0,而 P1.0也是等于1。 可用下列程序验证: ORG 0000H AJMP START ORG 30H START: MOV SP,#5FH MOV P1,#0FFH SETB C ANL C,/P1.0 MOV P1.1,C ;将做完的结果送 P1.1,结果应当是 P1.1上的灯亮,而 P1.0上的灯还是不亮
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
类似的还有累加器A:
INC A
寄存器寻址方式(单字节);
INC ACC 直接寻址方式(双字节);
INC 0E0H 直接寻址方式(双字节)。
3,在指令系统中:字节地址与位地址是完全不同的概念。 前者用direct表示,而后者用bit 表示,但在指令中都是用 16进制表示的数。 如:
MOV A,20H ;将RAM的20H单元内容送A MOV C,20H ;将位寻址区中的位地址为20H位内容送
1 1 1 0 1 r r r E8H~EFH
MOV A,Rn
操作码 寄存器代码
2.2.2 直接寻址
指令本身含有操作数的8位或16位地址。既指令直接给 出了操作数的地址。如:
MOV A,30H ;将RAM30H单元内容送累加器 这里30H是操作数在RAM中的地址。 很明显,直接寻址的指令长度是两个或三个字节。
变址指令只适用于对ROM存储器得访问,如查表等。
【举例】:已知ROM中0302H 单元有一个数x,现要把它送到 累加器A中,试编程。
MOV DPTR,#0300H ;立即数送DPTR
MOV A,#02H
;立即数送累加器A
MOVC A,@A+DPTR ;从ROM的00302单元取数送A
变址寻址示意图
03
02
01
00
返回前一次
2.2.3立即寻址
指令本身直接含有所需要的8位或16位的操作数。
将此数称为“立即数”(使用#标明)。如:
MOV A,#30H
;将(8位)立即数送累加器A
MOV DPTR,#2000H ;16位立即数送DPTR积存器
【注意】:MOV A,#30H MOV A,30H 两者的区别。 立即数寻址的指令长度为2或3个字节。
无操作数:如 INC DPTR 10100011B
INC A
00000100B
【特点】:操作数隐含在操作码中。
含有操作数寄存器名称的单字节指令:
如:MOV A,R0
1110100】:寄存器名以三位数代码的形式在指令的后三位。
双字节指令(46条):
指令的操作码和操作数各占一个字节。 如:
ROM n 74H n+1 30H
累加器A
返回
MOV A,#30H 指令执行流程
DPTR
ROM
90H 20H 00H
MOV DPTR,#2000H指令的存储和执行
2.2.4 寄存器间接寻址
指令中含有保存操作数地址的寄存器Ri。 MOV A,@Ri ( i=0、1)
CPU首先根据指令中寄存器名Ri找到操作数地址,然后再 从该地址中找到操作数 x。 如:MOV R0,#30H ;立即数送R0寄存器
“机器码”后才能为CPU所识别和执行。 3,三种不同的表示方法适用于不同的场合。
本章内容都以汇编的形式介绍指令系统。
2.1.3 指令的字节数
在MCS-51单片机的指令系统中,因指令操作码和操作数 的不同,指令(在存储器中)长度也各不相同。
分为单字节、双字节和三字节。
单字节指令(49条):分无操作数、有操作数两种。
三字节指令在存储器中存放的方式示意图
指令的字节数与指令的运行时间
指令的字节多是否意味着指令周期就长?
指令
字节数 周期数
MOV A,R0
1
1
MOV A,#0FFH 2
1
MOV 20H,#30H 3
2
MUL AB
1
4
INC DPTR
1
1
指令说明 R0内容送累加器A
立即数FFH送A 立即数30H送内存20h单元
特点: 能被CPU直接识别、运行的形式。也称机器码、汇编语 言的目标代码。
缺点:不便于阅读、记忆和调试修改。
2,十六进制表示方式: 它是对二进制形式的一种简化。
00100100B
24H
00001000B
08H
二进制表示的形式 十六进制表示的形式
在实验室等少数环境下,可以将这种形式作为输入程序 的一种辅助手段。但是,这种形式的指令格式必须由对应 的监控程序把它们翻译成二进制的“机器码”后存入程序 存储器并运行。
累加器A 02H
ALU
DPTR 0300H
0300H + 02H
MOV IE,#00H ;初始化中断允许寄存器 MOV TH1,#0FEH ;为定时器1赋初值 尽管使用SFR的寄存器名称来取代直接地址,可以带 来程序的可读性,但是在汇编时,仍要将寄存器名字转换 为直接地址。
2,当直接地址时在工作寄存器区中时,可以使用两种寻址 方式来访问。 如:
MOV A,00H ;将RAM中00H单元数据送累加器A
程序ROM
累加器A
数据RAM
n
OP
n+1
30H
30H 操作数x
直接寻址示意图
使用直接寻址应注意的三个问题:
1,指令助记符中direct是用16进制数表示的操作数地址。 当地址恰好在SFR区域时,指令也可以用寄存器名来表示。 如:
MOV A,80H 可以写成 MOV A,P0 后者用SFR中寄存器的名字取代它的物理地址80H。 很明显,后者更容易阅读和交流,所以我们提倡使用SFR 中寄存器名称来代替直接地址。 如:MOV A,SBUF ;串口数据缓冲器数据送A
或者:指令中分别包含1个字节的操作数和1个字节的操作 数地址。如:
MOV direct,#data 举例:MOV 20H,#0FFH
10010000 data15-8 data8-0
MOV direct,#data MOV dptr,#data16
OP (75H) direct (20H) data (FFH)
MOV A,#data
01110100B data
很明显:8位的操作数本身占据一个字节。
程序存储器
n 01110100 n+1 data
mov a,#data
双字节指令在程序存储器的存放示意图
三字节指令(16条):
指令中的操作数为双字节。如:
MOV DPTR,#data16 1001000B,data15-8,data7-0
3,指令的“助记符”方式(也称“汇编格式”):
00100100B 00001000B
24H 08H ADD A,#08H
二进制表示形式 十六进制表示
汇编格式
1,这是一种由英文单词或字母、数字来表征指令功能的 形式。是一种便于阅读、书写和交流的表示形式。
2,这种 “汇编”格式的指令必须把它“翻译”为二进制 形式
5,位操作指令:位传送、位置位、位运算和位控制转移等 操作。 【 特点】:按位操作而不是按字节的操作。位控转移的判 断不是检测某一个字节而是对某一个位进行检测并决定是 否进行程序转移。 这类指令基本不影响PSW的内容。
2.2 寻址方式
在指令的操作数位置上,用于表征、寻找操作数的方式定义 为“寻址方式”。
PSW 中的Cy中。
片内 RAM(20H-2FH)中的位寻址区结构图
2FH 7F
7E
7D
7C
7B
7A
79
78
77
76
75
74
73
72
71
70
6F
6E
6D
6C
6B
6A
69
68
67
66
65
64
63
62
61
60
5F
5E
5D
5C
5B
5A
59
58
57
56
55
54
53
52
51
50
字节地址
4F
4E
4D
4C
4B
4A
正确的理解、掌握寻址方式,是学习、使用指令的关键。
在MCS-51单片机中,共使用了七种寻址方式。 它们分别是:
1,寄存器寻址 2,直接寻址 3,立即数寻址 4,寄存器间接寻址
5,变址寻址; 6,相对寻址; 7,位寻址。
2.2.1寄存器寻址
当所需要的操作数在内部某一个寄存器Rn中时,将此寄存器 名Rn直接写在指令的操作数的位置上。如:
49
48
47
46
45
44
43
42
41
40
3F
3E
3D
3C
3B
3A
39
38
37
26
25
24
23
22
21
20
2F
2E
2D
2C
2B
2A
29
28
24H
27
26
25
24
23
22
21 20 位地址
1F
1E
1D
1C
1B
1A
19
18
17
16
15
14
13
12
11
10
0F
0E
0D
0C
0B
0A
09
08
20H
07
06
05
04
3,间址方式的指令不能访问SFR中的单元。如下面的程序 是错误的: MOV R1,#80H MOV A,@R1 (因为80H为SFR的物理地址)
MCS-51 片内 、片外 数据存储器示意图
FFH 特殊功能 寄存器 SFR
80H 7FH
通用数据 存储器
00H
片内数据存储器 256B个字节
FFFFH
注意:
MOV A,R7 ;将寄存器R7中的内容送累加器A中。
MOV 20H,R0 ;将寄存器R0中的数据送内存20H单元