MCS-51汇编语言常用指令集
来源:互联网 发布:4k网络电视什么牌子好 编辑:程序博客网 时间:2024/05/18 02:03
51汇编语言指令集
符号定义表
符号 含义
Rn R0~R7寄存器n=0~7
Direct 直接地址,内部数据区的地址RAM(00H~7FH)
SFR(80H~FFH) B,ACC,PSW,IP,P3,IE,P2,SCON,P1,TCON,P0
@Ri 间接地址Ri=R0或R1 8051/31RAM地址(00H~7FH) 8052/32RAM地址(00H~FFH)
#da
#da
Addr16 16位的目标地址
Addr11 11位的目标地址
Rel 相关地址
bit 内部数据RAM(20H~2FH),特殊功能寄存器的直接地址的位
指令介绍
指令 字节 周期 动作说明
算数运算指令
1.ADD A,Rn 1 1 将累加器与寄存器的内容相加,结果存回累加器
2.ADD A,direct 2 1 将累加器与直接地址的内容相加,结果存回累加器
3.ADD A,@Ri 1 1 将累加器与间接地址的内容相加,结果存回累加器
4.ADD A,#da
5.ADDC A,Rn 1 1 将累加器与寄存器的内容及进位C相加,结果存回累加器
6.ADDC A,direct 2 1 将累加器与直接地址的内容及进位C相加,结果存回累加器
7.ADDC A,@Ri 1 1 将累加器与间接地址的内容及进位C相加,结果存回累加器
8.ADDC A,#da
9.SUBB A,Rn 1 1 将累加器的值减去寄存器的值减借位C,结果存回累加器
10.SUBB A,direct 2 1 将累加器的值减直接地址的值减借位C,结果存回累加器
11.SUBB A,@Ri 1 1 将累加器的值减间接地址的值减借位C,结果存回累加器
12.SUBB A,#da
13.INC A 1 1 将累加器的值加1
14.INC Rn 1 1 将寄存器的值加l
15.INC direct 2 1 将直接地址的内容加1
16.INC @Ri 1 1 将间接地址的内容加1
17.INC DPTR 1 1 数据指针寄存器值加1
说明:将16位的DPTR加1,当DPTR的低字节(DPL)从FFH溢出至00H时,会使高字节(DPH)加1,不影响任何标志位
18.DEC A 1 1 将累加器的值减1
19.DEC Rn 1 1 将寄存器的值减1
20.DEC direct 2 1 将直接地址的内容减1
21.DEC @Ri 1 1 将间接地址的内容减1
22.MUL AB 1 4 将累加器的值与B寄存器的值相乘,乘积的低位字节存回累加器,高位字节存回B寄存器
说明:将累加器A和寄存器B内的无符号整数相乘,产生16位的积,低位字节存入A,高位字节存入B寄存器。如果积大于FFH,则溢出标志位(OV)被设定为1,而进位标志位为0
23.DIV AB 1 4 将累加器的值除以B寄存器的值,结果的商存回累加器,余数存回B寄存器
说明:无符号的除法运算,将累加器A除以B寄存器的值,商存入A,余数存入B。执行本指令后,进位位(C)及溢出位(OV)被清除为0
24.DA A 1 1 将累加器A作十进制调整,
若(A) 3-0>9或(AC)=1,则(A) 3-0←(A)3-0+6
若(A) 7-4>9或 (C)=1,则(A) 7-4←(A)7-4+6
逻辑运算指令
25.ANL A,Rn 1 1 将累加器的值与寄存器的值做AND的逻辑判断,结果存回累加器
26.ANL A,direct 2 1 将累加器的值与直接地址的内容做AND的逻辑判断,结果存回累加器
27.ANL A,@Ri 1 1 将累加器的值与间接地址的内容做AND的逻辑判断,结果存回累加器
28.ANL A,#da
29.ANL direct,A 2 1 将直接地址的内容与累加器的值做AND的逻辑判断,结果存回该直接地址
30.ANL direct,#da
31.ORL A,Rn 1 1 将累加器的值与寄存器的值做OR的逻辑判断,结果存回累加器
32.ORL A,direct 2 1 将累加器的值与直接地址的内容做OR的逻辑判断,结果存回累加器
33.ORL A,@Ri 1 1 将累加器的值与间接地址的内容做OR的逻辑判断,结果存回累加器
34.ORL A,#da
35.ORL direct,A 2 1 将直接地址的内容与累加器的值做OR的逻辑判断,结果存回该直接地址
36.ORL direct,#da
37.XRL A,Rn 1 1 将累加器的值与寄存器的值做XOR的逻辑判断,结果存回累加器
38.XRL A,direct 2 1 将累加器的值与直接地址的内容做XOR的逻辑判断,结果存回累加器
39.XRL A,@Ri 1 1 将累加器的值与间接地扯的内容做XOR的逻辑判断,结果存回累加器
40.XRL A,#da
41.XRL direct,A 2 1 将直接地址的内容与累加器的值做XOR的逻辑判断,结果存回该直接地址
42.XRL direct,#da
43.CLR A 1 1 清除累加器的值为0
44.CPL A 1 1 将累加器的值反相
45.RL A 1 1 将累加器的值左移一位
46.RLC A 1 1 将累加器含进位C左移一位
47.RR A 1 1 将累加器的值右移一位
48.RRC A 1 1 将累加器含进位C右移一位
49.SWAP A 1 1 将累加器的高4位与低4位的内容交换。(A)3-0←(A)7-4
数据转移指令
50.MOV A,Rn 1 1 将寄存器的内容载入累加器
51.MOV A,direct 2 1 将直接地址的内容载入累加器
52.MOV A,@Ri 1 1 将间接地址的内容载入累加器
53.MOV A,#da
54.MOV Rn,A 1 1 将累加器的内容载入寄存器
55.MOV Rn,direct 2 2 将直接地址的内容载入寄存器
56.MOV Rn,gdata 2 1 将常数载入寄存器
57.MOV direct,A 2 1 将累加器的内容存入直接地址
58.MOV direct,Rn 2 2 将寄存器的内容存入直接地址
59.MOV direct1, direct2 3 2 将直接地址2的内容存入直接地址1
60.MOV direct,@Ri 2 2 将间接地址的内容存入直接地址
61.MOV direct,#da
62.MOV @Ri,A 1 1 将累加器的内容存入某间接地址
63.MOV @Ri,direct 2 2 将直接地址的内容存入某间接地址
64.MOV @Ri,#da
65.MOV DPTR,#da
66.MOVC A,@A+DPTR 1 2 (A) ←((A)+(DPTR))
累加器的值再加数据指针寄存器的值为其所指定地址,将该地址的内容读入累加器
67.MOVC A,@A+PC 1 2 (PC)←(PC)+1;(A)←((A)+(PC))累加器的值加程序计数器的值作为其所指定地址,将该地址的内容读入累加器
68.MOVX A,@Ri 1 2 将间接地址所指定外部存储器的内容读入累加器(8位地址)
69.MOVX A,@DPTR 1 2 将数据指针所指定外部存储器的内容读入累加器(16位地址)
70.MOVX @Ri,A 1 2 将累加器的内容写入间接地址所指定的外部存储器(8位地址)
71.MOVX @DPTR,A 1 2 将累加器的内容写入数据指针所指定的外部存储器(16位地址)
72.PUSH direct 2 2 将直接地址的内容压入堆栈区
73.POP direct 2 2 从堆栈弹出该直接地址的内容
74.XCH A,Rn 1 1 将累加器的内容与寄存器的内容互换
75.XCH A,direct 2 1 将累加器的值与直接地址的内容互换
76.XCH A,@Ri 1 1 将累加器的值与间接地址的内容互换
77.XCHD A,@Ri 1 1 将累加器的低4位与间接地址的低4位互换
布尔代数运算
78.CLR C 1 1 清除进位C为0
79.CLR bit 2 1 清除直接地址的某位为0
80.SETB C 1 1 设定进位C为1
81.SETB bit 2 1 设定直接地址的某位为1
82.CPL C 1 1 将进位C的值反相
83.CPL bit 2 1 将直接地址的某位值反相
84.ANL C,bit 2 2 将进位C与直接地址的某位做AND的逻辑判断,结果存回进位C
85.ANL C,/bit 2 2 将进位C与直接地址的某位的反相值做AND的逻辑判断,结果存回进位C
86.ORL C,bit 2 2 将进位C与直接地址的某位做OR的逻辑判断,结果存回进位C
87.ORL C,/bit 2 2 将进位C与直接地址的某位的反相值做OR的逻辑判断,结果存回进位C
88.MOV C,bit 2 1 将直接地址的某位值存入进位C
89.MOV bit,C 2 2 将进位C的值存入直接地址的某位
90.JC rel 2 2 若进位C=1则跳至rel的相关地址
91.JNC rel 2 2 若进位C=0则跳至rel的相关地址
92.JB bit,rel 3 2 若直接地址的某位为1,则跳至rel的相关地址
93.JNB bit,rel 3 2 若直接地址的某位为0,则跳至rel的相关地址
94.JBC bit,rel 3 2 若直接地址的某位为1,则跳至rel的相关地址,并将该位值清除为0
程序跳跃
95.ACALL addr11 2 2 调用2K程序存储器范围内的子程序
96.LCALL addr16 3 2 调用64K程序存储器范围内的子程序
97.RET 1 2 从子程序返回
98.RETI 1 2 从中断子程序返回
99.AJMP addr11 2 2 绝对跳跃(2K内)
100.LJMP addr16 3 2 长跳跃(64K内)
101.SJMP rel 2 2 短跳跃(2K内)-128~+127字节
102.JMP @A+DPTR 1 2 跳至累加器的内容加数据指针所指的相关地址
103.JZ rel 2 2 累加器的内容为0,则跳至rel所指相关地址
104.JNZ rel 2 2 累加器的内容不为0,则跳至rel所指相关地址
105.CJNE A,direct,rel 3 2 将累加器的内容与直接地址的内容比较,不相等则跳至rel所指的相关地址
106.CJNE A,#da
107.CJNE @Rn,#da
108.CJNE @Ri,#da
109.DJNZ Rn,rel 2 2 将寄存器的内容减1,不等于0则跳至rel所指的相关地址
110.DJNZ direct,rel 3 2 将直接地址的内容减1,不等于0则跳至rel所指的相关地址
111.NOP 1 1 无动作
注: cjne a,#da
当a<#da
CJNE A,direct,rel ;if(direct)<(A),PC←(PC)+3+rel,and CY←0 ;CJNE compare instruction
; ;if(direct)>(A),PC←(PC)+3+rel,and CY←1
; ;if(direct)=(A),PC←(PC)+3,and CY←0
; CJNE A,#data,rel ;ifdata<(A),PC←(PC)+3+rel,and CY←0
; ;ifdata>(A),PC←(PC)+3+rel,and CY←1
; ;ifdata=(A),PC←(PC)+3,and CY←0
; CJNE Rn,#data,rel ;ifdata<(Rn),PC←(PC)+3+rel,and CY←0
; ;ifdata>(Rn),PC←(PC)+3+rel,and CY←1
; ;ifdata=(Rn),PC←(PC)+3,and CY←0
; CJNE @Ri,#data,rel ;ifdata<((Ri)),PC←(PC)+3+rel,and CY←0
; ;ifdata>((Ri)),PC←(PC)+3+rel,and CY←1
; ;ifdata=((Ri)),PC←(PC)+3,and CY←0
CJNE是比较转移指令,该指令通过比较前面两个操作数的大小,如果它们的值不相等则转移,相等则继续执行。指令执行后要影响进位位CY,若操作数1小于操作数2,则CY=1;若操作数1大于操作数2,则CY=0
8种常用伪指令
1.ORG 16位地址 ;此指令用在原程序或数据块的开始,指明此语句后面目标程序或数据块存放的起始地址。
2.[标号:] DB 字节数据项表 ;将项表中的字节数据存放到从标号开始的连续字节单元中。例如:SEG: DB 88H,100,“7”,“C”
3.[标号:]DW 双字节数据项表 ;定义16位地址表,16地址按低位地址存低位字节,高位地址存高位字节。例如:TAB: DW 1234H,7BH
4.名字 EQU 表达式 或名字=表达式 ;用与给一个表达式赋值或给字符串起名字。之后名字可用做程序地址,数据地址或立即数地址使用。名字必须是一字母开头的字母数字串。 例如:COUNT=10 或 SPACE EQU 10H
5.名字 DATA 直接字节地址 ;给8位内部RAM单元起个名字,名字必须是一字母开头的字母数字串。同一单元可起多个名字。 例如:ERROR DATA 80H
6.名字 XDATA 直接字节地址 ;给8位外部RAM起个名字,名字规定同DATA 伪指令。例如:IO_PORT XDATA 0CF04H
7.名字 BIT 位指令 ;给一可位寻址的位单元起个名字,规定同DATA伪指令。例如:SWT BIT 30H
8.[标号:] END ;指出源程序到此结束,汇编对其后的程序语句不予理睬.源程序只在主程序最后使用一个END
MCS51汇编指令
指令格式(助记符)
指令功能说明
字节
周期
MOV A,direct
(direct)→(A) 直接单元地址中的数据→累加器A
1
1
MOV A,#data
#data→(A) 8位立即数→累加器A
2
1
MOV A,Rn
(Rn )→(A) Rn寄存器中的数据→累加器A
1
1
MOV A,@Ri
((Ri))→(A) Ri中的数据指向的地址单元中的数据 →累加器A
1
1
MOV Rn,direct
(direct)→(Rn) 直接寻址单元中的数据 —> 寄存器Rn
2
2
MOV Rn,#data
#data→(Rn) 8位立即数 —> 寄存器Rn
2
1
MOV Rn,A
(A)→(Rn) 累加器A中的数据 —> 寄存器Rn
1
1
MOV direct,direct
(direct)→(direct) 直接地址单元中的数据→直接地址单元direct
3
2
MOV direct,#data
#data→(direct) 立即数→直接地址单元direct
3
2
MOV direct,A
(A)→(direct) 累加器A中的数据→直接地址单元direct
2
2
MOV direct,Rn
(Rn)→(direct) 寄存器Rn中的数据→直接地址单元direct
2
2
MOV direct,@Ri
((Ri))→(direct) 寄存器Ri中的数据指定的地址单元中数据→直接地址单元direct
2
2
MOV @Ri,direct
(direct)→((Ri)) 直接地址单元中的数据→以Ri中的内容为地址的RAM单元
2
2
MOV @Ri,#data
#data→((Ri)) 立即数→以Ri中的内容为地址的RAM单元
2
1
MOV @Ri,A
(A)→((Ri)) 累加器A中的数据→以Ri中的内容为地址的RAM单元
1
1
MOVC A,@A+DPTR
((A))+(DPTR)→(A) 表格地址单元中的数据→累加器A
3
2
MOVC A,@A+PC
((PC))+1→(A),((A))+(PC)→(A) 表格地址单元中的数据→累加器A
1
2
MOVX @DPTR,A
(A)→((DPTR)) 累加器中的数据→数据指针指向片外RAM地址中
3
2
MOVX A, @DPTR
(A)→((DPTR)) 累加器中的数据 → 数据指针指向片外RAM地址中
3
2
MOVX A, @Ri
((Ri))→(A) 寄存器Ri指向片外RAM地址中的数据→累加器A中
1
2
MOVX @Ri,A
(A)→((Ri)) 累加器中的数据→寄存器Ri指向片外RAM地址中
1
2
PUSH direct
(SP)+1→(SP),(direct)→(SP) 堆栈指针首先加1,直接寻址单元中的数据送到堆栈指针SP所指的单元中
2
2
PUSH A
将累加器A中的数据→堆栈顶端
2
2
POP direct
(SP)→(direct)(SP)-1→(SP), 堆栈指针SP所指的单元数据送到直接寻址单元中,堆栈指针SP再进行减1操作
2
2
POP A
将堆栈顶端的数据→累加器A
2
2
XCH A,Rn
(A)←→(Rn)累加器与工作寄存器Rn中的数据互换
1
1
XCH A,@Ri
(A)←→((Ri))累加器与工作寄存器Ri所指的存储单元中的数据互换
1
1
XCH A, direct
(A)←→(direct)累加器与直接地址单元中的内容互换
2
2
XCHD A,@Ri
(A3-0)←→((Ri)3-0)累加器与工作寄存器Ri所指的存储单元中的数据低半字节互换
1
1
SWAP A
(A3-0)←→(A7-4)累加器中的内容高低半字节互换
1
1
MOV DPTR,#data16
#dataH→(DPH),#dataL→(DPL)16位常数的高8位送到DPH,低8位送到DPL
3
2
ADD A,#data
A)+#data→(A) 累加器A中的数据与立即数#data相加,结果存在A中
2
1
ADD A,direct
A)+(direct)→(A) 累加器A中的数据与直接地址单元中的数据相加,结果存在A中
2
1
指令格式(助记符)
指令功能说明
字节
周期
ADD A,Rn
(A)+(Rn)→(A) 累加器A中的数据与工作寄存器Rn中的数据相加,结果存在A中
1
1
ADD A,@Ri
(A)+((Ri))→(A) 累加器A中的数据与工作寄存器Ri所指向地址单元中的数据相加,结果存在A中
1
1
ADDC A,direct
(A)+(direct)+(C)→(A) 累加器A中的数据与直接地址单元的数据连同进位位相加,结果存在A中
2
1
ADDC A,#data
(A)+#data +(C)→(A) 累加器A中的数据与立即数连同进位位相加,结果存在A中
2
1
ADDC A,Rn
A)+Rn+(C)→(A) 累加器A中的数据与工作寄存器Rn中的数据、连同进位位相加,结果存在A中
1
1
ADDC A,@Ri
(A)+((Ri))+(C)→(A) 累加器A中的数据与工作寄存器Ri指向地址单元中的数据、连同进位位相加,结果存在A中
1
1
SUBB A,direct
(A)-(direct)-(C)→(A) 累加器A中的数据与直接地址单元中的数据、连同借位位相减,结果存在A中
2
1
SUBB A,#data
(A)-(Rn)-(C)→(A) 累加器A中的数据与工作寄存器中的数据、连同借位位相减,结果存在A中
2
1
SUBB A,Rn
(A)-(Rn)-(C)→(A) 累加器A中的数据与工作寄存器中的数据、连同借位位相减,结果存在A中
1
1
SUBB A,@Ri
(A)-((Ri))-(C)→(A) 累加器A中的数据与工作寄存器Ri指向的地址单元中的数据、连同借位位相减,结果存在A中
1
1
MUL AB
(A)×(B)→(A)和(B) 累加器A中的数据乘以寄存器B中的数据,结果高字节存入寄存器B,底字节存入累加器A
1
4
DIV AB
(A)÷(B)→(A)和(B) 累加器A中的数据除以寄存器B中的数据,结果的商存入累加器A,余数存入寄存器B中
1
4
INC A
+1?ú(A) 累加器A中的数据加1,结果存在A中
1
1
INC direct
(direct)+1→(direct) 直接地址单元中的数据加1,结果送回原地址单元中,如果直接地址是I/O,其功能是先读入I/O锁存器的内容,然后在CPU进行加1操作,再输出到I/O上,这就是“读—修改—写”操作
2
1
INC @Ri
((Ri))+1→((Ri)) 寄存器的数据指向的地址单元中的数据加1,结果送回原地址单元中
1
1
NC Rn
Rn)+1→(Rn)寄存器Rn的数据加1,结果送回原地址单元
1
1
INC DPTR
(DPTR)+1→(DPTR)数据指针的数据加1,结果送回数据指针中
1
2
DEC A
(A)-1→(A)累加器A中的数据减1,结果送回累加器A
1
1
DEC direct
(direct)-1→(direct)直接地址单元中的数据减1,结果送回直接地址单元中
2
1
DEC @Ri
((Ri))-1→((Ri))寄存器Ri指向的地址单元中的数据减1,结果送回原地址单元中
1
1
DEC Rn
(Rn)-1→(Rn)寄存器Rn中的数据减1,结果送回寄存器Rn中
1
1
DA A
累加器A中的数据做BCD调整
1
1
RL A
累加器A中的数据左移一位,bit7?úbit0
1
1
RR A
累加器A中的数据右移一位,bit7?úbit7
1
1
RLC A
累加器A中的数据连同进位标志位CY左移一位,bit7?úCY,CY?úbit0
1
1
RRC A
累加器A中的数据连同进位CY位CY右移一位,bi0?úCY,CY?úbit7
1
1
SWAP A
累加器中的数据高低半字节互换
1
1
CPL A
累加器中的数据按位取反,即0?ú1,1?ú0
1
1
CLR A
0?ú(A),累加器中的数据清0H
1
1
ANL A,direct
累加器A中的数据和直接地址单元中的数据执行与操作。结果存在寄存器A中
2
1
ANL direct,#data
直接地址单元中的数据和立即数执行与操作。结果存在直接地址单元中
3
2
指令格式(助记符)
指令功能说明
字节
周期
NL A,#data
累加器A的数据和立即数执行与操作。结果存在累加器A中
2
1
NL A,Rn
累加器A的数据和寄存器Rn中的数据执行与操作。结果存在累加器A中
1
1
ANL direct,A
直接地址单元中的数据和累加器A的数据执行与操作。结果存在直接地址单元中
2
1
ANL A,@Ri
累加器A的数据和工作寄存器Ri指向的地址单元中的数据执行与操作。结果存在累加器A中
1
1
ORL A,direct
累加器A中的数据和直接地址单元中的数据执行逻辑或操作。结果存在寄存器A中
2
1
ORL direct,#data
累加器A中的数据和直接地址单元中的数据执行逻辑或操作。结果存在寄存器A中
3
2
ORL A,#data
累加器A的数据和立即数执行逻辑或操作。结果存在累加器
2
1
ORL A,Rn
累加器A的数据和寄存器Rn中的数据执行逻辑或操作。结果存在累加器A中
1
1
ORL direct,A
直接地址单元中的数据和累加器A的数据执行逻辑或操作。结果存在直接地址单元中
2
1
ORL A,@Ri
累加器A的数据和工作寄存器Ri指向的地址单元中的数据执行逻辑或操作。结果存在累加器A中
1
1
XRL A,direct
累加器A中的数据和直接地址单元中的数据执行逻辑异或操作。结果存在寄存器A中
2
1
XRL direct,#data
直接地址单元中的数据和立即数执行逻辑异或操作。结果存在直接地址单元中
3
2
XRL A,#data
累加器A的数据和立即数执行逻辑异或操作。结果存在累加器A中
2
1
XRL A,Rn
累加器A的数据和寄存器Rn中的数据执行逻辑异或操作。结果存在累加器A中
1
1
XRL data,A
直接地址单元中的数据和累加器A的数据执行逻辑异或操作。结果存在直接地址单元中
2
1
XRL A,@Ri
累加器A的数据和工作寄存器Ri指向的地址单元中的数据执行逻辑异或操作。结果存在累加器A中
1
1
CLR C
清除进位标志CY为0
1
1
CLR bit
清除bit为0
2
1
SETB C
设定进位标志CY为1
1
1
SETB bit
设定bit为1
2
1
CPL C
将进位标志CY反相
1
1
CPL bit
将bit反相
2
1
ANL C,bit
将进位标志CY AND bit值?ú进位标志位CY
2
2
ANL C,/bit
将进位标志CY AND bit反相值?ú进位标志位CY
2
2
ANL A,#data
将累加器A的各位与立即数的相对位置做AND?úA累加器
2
2
ORL C,bit
将进位标志CY OR bit值?ú进位标志位CY
2
2
ORL C,/bit
将进位标志CY OR bit反相值?ú进位标志位CY
2
2
ORL A,#data
将累加器A的各位与立即数的相对位置做OR?úA累加器
2
2
MOV C,bit
将bit值?ú进位标志位CY
2
1
MOV bit,C
将进位标志位CY?úbit值
2
2
JC rel
当进位标志位CY=1就跳至rel,否则执行下一条指令
2
2
JNC rel
当进位标志位CY=0就跳至rel,否则执行下一条指令
2
2
JB bit rel
当进bit=1就跳至rel,否则执行下一条指令
3
3
JNB bit rel
当进bit=0就跳至rel,否则执行下一条指令
3
3
JBC bit rel
当进bit=1跳至rel,并且清除此bit为0,否则执行下一条指令
3
3
ACALL addr11
2K范围内子程序调用
2
2
LCALL addr16
64K范围内子程序调用
3
3
RET
子程序返回
1
2
RET1
中断服务程序结束返回
1
2
指令格式(助记符)
指令功能说明
字节
周期
AJMP addr11
2K范围内无条件跳转
2
2
LJMP addr16
64K范围内无条件跳转
2
2
SJMP rel
在此指令的前128或后128范围内无条件跳转
2
2
JMP @A+DPTR
跳至@A+DPTR所指定的地址
1
2
JZ rel
如A的内容为0,则短跳转,负责执行下一条指令
2
2
JNZ rel
如A的内容不为0,则短跳转,负责执行下一条指令
2
2
CJNE A,direct,rel
如A的内容与直接地址内的数据不同,则短跳转
3
2
CJNE A,#data,rel
如A的内容与立即数不同,则短跳转
3
2
CJNE Rn,#data,rel
如Rn寄存器中的数据与立即数不同,则短跳转
3
2
CJNE @Ri,#data,rel
如间接地址的数据与立即数不同,则短跳转
3
2
DJNZ Rn,rel
Rn寄存器中的数据减1,若不为0,则短跳转,否则执行下条指令
2
2
DJNZ direct,rel
直接地址中的数据减1,若不为0,则短跳转,负责执行下条指令
3
2
NOP
CPU仅仅作取指令,不动作
1
1
- MCS-51汇编语言常用指令集
- 汇编语言常用指令集
- MCS-51汇编指令
- MCS-51单片机常用伪指令及常见出错表
- 51汇编语言指令集
- 51汇编语言指令集
- MCS-51 汇编指令集(A开头的指令)
- MCS-51 汇编指令集(C开头的指令)
- MCS-51 汇编指令集(D开头的指令)
- MCS-51 汇编指令集(I开头的指令)
- MCS-51 汇编指令集(J开头的指令)
- MCS-51 汇编指令集(L开头的指令)
- MCS-51 汇编指令集(M开头的指令)
- MCS-51 汇编指令集(N开头的指令)
- MCS-51 汇编指令集(O开头的指令)
- MCS-51 汇编指令集(P开头的指令)
- MCS-51 汇编指令集(R开头的指令)
- MCS-51 汇编指令集(S开头的指令)
- BUG: Cannot load from mysql.proc. The table is probably corrupted
- objective-c block 讲解
- cocos2d 粒子效果2
- lcd驱动调试常见问题总结
- pre-link的app无法内置显示在idle上
- MCS-51汇编语言常用指令集
- 触摸屏驱动调试常见问题总结
- 感知哈希算法"(Perceptual hash algorithm)
- PCL Kinect Fusion项目安装配置
- 如何将当前窗口带到带到最顶层,并设置为活动窗口
- key驱动调试问题总结
- 向 ReportViewer 报表中添加图表
- linux “ll” 命令实现
- 按位与、按位或