单片机汇编指令大全
- 格式:docx
- 大小:22.03 KB
- 文档页数:4
51单片机汇编指令详解mcs-51系列单片机指令目录:1、a2、x3、r4、s5、n6、o7、p8、m9、j10、l11、d12、i13、c一、以a结尾的指令存有18条,分别为:acalladdr11adda,rnadda,directadda,@riadda,#dataaddca,rnaddca,directaddca,@riaddca,#dataajmpaddr11anla,rnanla,directanla,@rianla,#dataanldirect,aanldirect,#dataanlc,bitanlc,/bit1、acalladdr11指令名称:绝对调用指令指令代码:{a10,a9,a8,10001},a[7:0]指令功能:结构目的地址,展开子程序调用。
其方法就是以指令提供更多的11十一位地址(al0~a0),替代pc的高11十一位,pc的高5十一位维持不变。
操作方式内容:pc←(pc)+2sp←(sp)+1(sp)←(pc)7~0sp←(sp)+1(sp)←(pc)15~8pc10~0←addrl0~0字节数:2机器周期:2采用表明:由于指令只得出子程序入口地址的高11十一位,因此调用范围就是2kb。
2、adda,rn指令名称:寄存器乘法指令指令代码:28h~2fh指令功能:累加器内容与寄存器内容相加操作内容:a←(a)+(rn),n=0~7字节数:1机器周期;1影响标志位:c,ac,ov3、adda,direct指令名称:轻易串行乘法指令指令代码:25h指令功能:累加器内容与内部ram单元或专用寄存器内容相加操作内容:a←(a)+(direct)字节数:2机器周期:1影响标志位:c,ac,ov4、adda,@ri指令名称:间接串行乘法指令指令代码:26h~27h指令功能:累加器内容与内部ram高128单元内容相乘操作方式内容:a←(a)+((ri)),i=0,1字节数:1机器周期:1影响标志位:c,ac,ov5、adda,#data指令名称:立即数加法指令指令代码:24h指令功能:累加器内容与立即数相乘操作方式内容:a←(a)+data字节数:2机器周期:1影响标志位:c,ac,ov6、addca,rn指令名称:寄存器带进位加法指令指令代码:38h~3fh指令功能:累加器内容、寄存器内容和位次位相乘操作方式内容:a←(a)+(rn)+(c),n =0~7字节数:1机器周期:1影响标志位:c,ac,ov7、addca,direct指令名称:直接寻址带进位加法指令指令代码:35h指令功能:累加器内容、内部ram高128单元或专用寄存器内容与位次位加操作内容:a←(a)+(direct)+(c)字节数:2机器周期:1影响标志位:c,ac,ov8、addca,@ri指令名称:间接串行拎位次乘法指令指令代码:36h~37h指令功能:累加器内容、内部ram低128单元内容及进位位相加操作方式内容:a←(a)+((ri))+(c),i=0,1字节数:1机器周期:1影响标志位:c,ac,ov9、addca,#data指令名称:立即数带位次乘法指令指令代码:34h指令功能:累加器内容、立即数及进位位相加操作内容:a←(a)+data+(c)字节数:2机器周期:1影响标志位:c,ac,ov10、ajmpaddr11指令名称:绝对迁移指令指令代码:{a10,a9,a8,00001},a[7:0]指令功能:构造目的地址,实现程序转移。
单片机指令大全
单片机指令大全是一种汇编语言和机器语言结合的指令集,它在微处理器内部执行,包括算术运算指令、数据传送指令、控制流指令、I/O操作指令等。
常用的单片机指令大全如下:
1. MOV:移动指令,将源操作数的值移动到目标操作数中。
2. ADD:加法指令,将源操作数的值加上目标操作数的值,并将结果存储在目标操作数中。
3. SUB:减法指令,将源操作数的值减去目标操作数的值,并将结果存储在目标操作数中。
4. CMP:比较指令,比较源操作数的值和目标操作数的值,并设置标志位来标识结果是否大于、小于或等于。
5. AND:逻辑与指令,将源操作数的值与目标操作数的值按位与,并将结果存储在目标操作数中。
6. OR:逻辑或指令,将源操作数的值与目标操作数的值按位或,并将结果存储在目标操作数中。
7. XOR:逻辑异或指令,将源操作数的值与目标操作数的值按位异或,并将结果存储在目标操作数中。
8. JMP:无条件跳转指令,跳转到指定的指令地址。
9. JZ:当ZF(零标志)=1时跳转,跳转到指定的指令地址。
10. JC:当CF(进位标志)=1时跳转,跳转到指定的指令地址。
汇编语言的所有指令数据传送指令集MOV功能: 把源操作数送给目的操作数语法: MOV 目的操作数,源操作数格式: MOV r1,r2MOV r,mMOV m,rMOV r,dataXCHG功能: 交换两个操作数的数据语法: XCHG格式: XCHG r1,r2 XCHG m,r XCHG r,mPUSH,POP功能: 把操作数压入或取出堆栈语法: PUSH 操作数POP 操作数格式: PUSH r PUSH M PUSH data POP r POP mPUSHF,POPF,PUSHA,POPA功能: 堆栈指令群格式: PUSHF POPF PUSHA POPALEA,LDS,LES功能: 取地址至寄存器语法: LEA r,m LDS r,m LES r,mXLAT(XLATB)功能: 查表指令语法: XLAT XLAT m算数运算指令ADD,ADC功能: 加法指令语法: ADD OP1,OP2 ADC OP1,OP2格式: ADD r1,r2 ADD r,m ADD m,r ADD r,data影响标志: C,P,A,Z,S,OSUB,SBB功能:减法指令语法: SUB OP1,OP2 SBB OP1,OP2格式: SUB r1,r2 SUB r,m SUB m,r SUB r,data SUB m,data影响标志: C,P,A,Z,S,OINC,DEC功能: 把OP的值加一或减一语法: INC OP DEC OP格式: INC r/m DEC r/m影响标志: P,A,Z,S,ONEG功能: 将OP的符号反相(取二进制补码)语法: NEG OP格式: NEG r/m影响标志: C,P,A,Z,S,OMUL,IMUL功能: 乘法指令语法: MUL OP IMUL OP格式: MUL r/m IMUL r/m影响标志: C,P,A,Z,S,O(仅IMUL会影响S标志)DIV,IDIV功能:除法指令语法: DIV OP IDIV OP格式: DIV r/m IDIV r/mCBW,CWD功能: 有符号数扩展指令语法: CBW CWDAAA,AAS,AAM,AAD功能: 非压BCD码运算调整指令语法: AAA AAS AAM AAD影响标志: A,C(AAA,AAS) S,Z,P(AAM,AAD)DAA,DAS功能: 压缩BCD码调整指令语法: DAA DAS影响标志: C,P,A,Z,S位运算指令集AND,OR,XOR,NOT,TEST功能: 执行BIT与BIT之间的逻辑运算语法: AND r/m,r/m/data OR r/m,r/m/data XOR r/m,r/m/data TEST r/m,r/m/data NOT r/m 影响标志: C,O,P,Z,S(其中C与O两个标志会被设为0) NOT指令不影响任何标志位SHR,SHL,SAR,SAL功能: 移位指令语法: SHR r/m,data/CL SHL r/m,data/CL SAR r/m,data/CL SAL r/m,data/CL影响标志: C,P,Z,S,OROR,ROL,RCR,RCL功能: 循环移位指令语法: ROR r/m,data/CL ROL r/m,data/CL RCR r/m,data/CL RCL r/m,data/CL 影响标志: C,P,Z,S,O程序流程控制指令集CLC,STC,CMC功能: 设定进位标志语法: CLC STC CMC标志位: CCLD,STD功能: 设定方向标志语法: CLD STD标志位: DCLI,STI功能: 设定中断标志语法: CLI STI标志位: ICMP功能: 比较OP1与OP2的值语法: CMP r/m,r/m/data标志位: C,P,A,Z,OJMP功能: 跳往指定地址执行语法: JMP 地址JXX功能: 当特定条件成立则跳往指定地址执行语法: JXX 地址注:A: ABOVE,当C=0,Z=0时成立B: BELOW,当C=1时成立C: CARRY,当弁时成立CXZ: CX寄存器的值为0(ZERO)时成立E: EQUAL,当Z=1时成立G: GREATER(大于),当Z=0且S=0时成立L: LESS(小于),当S不为零时成立N: NOT(相反条件),需和其它符号配合使用O: OVERFLOW,O=1时成立P: PARITY,P=1时成立PE: PARITY EVEN,P=1时成立PO: PARITY ODD,P=0时成立S: SIGN,S=1时成立Z: ZERO,Z=1时成立LOOP功能: 循环指令集语法: LOOP 地址LOOPE(Z)地址LOOPNE(Z) 地址标志位: 无CALL,RET功能: 子程序调用,返回指令语法: CALL 地址RET RET n标志位: 无INT,IRET功能: 中断调用及返回指令语法: INT n IRET标志位: 在执行INT时,CPU会自动将标志寄存器的值入栈,在执行IRET时则会将堆栈中的标志值弹回寄存器字符串操作指令集MOVSB,MOVSW,MOVSD功能: 字符串传送指令语法: MOVSB MOVSW MOVSD标志位: 无CMPSB,CMPSW,CMPSD功能: 字符串比较指令语法: CMPSB CMPSW CMPSD标志位: C,P,Z,S,OSCASB,SCASW功能: 字符串搜索指令语法: SCASB SCASW标志位: C,P,Z,S,OLODSB,LODSW,STOSB,STOSW功能: 字符串载入或存贮指令语法: LODSB LODSW STOSB STOSW标志位: 无REP,REPE,REPNE功能: 重复前缀指令集语法: REP 指令S REPE 指令S REPNE 指令S标志位: 依指令S而定对于IBM PC机它有它的指令系统,其中包括:数据传送指令、串处理指令、算术指令、控制移动指令、逻辑指令、处理机控制指令。
单片机汇编指令单片机(Microcontroller)是一种集成了微处理器和其他外设的集成电路芯片,用于控制各种电子设备。
在单片机的开发过程中,编程是必不可少的一部分,而汇编语言是一种常用于单片机编程的低级语言。
汇编语言是一种和机器语言十分接近的编程语言,使用简单的助记符(Mnemonic)来代表机器指令,方便程序员进行编程。
在单片机开发中,汇编语言的指令集是非常重要的知识,掌握好单片机的汇编指令对于编写高效、性能优良的程序至关重要。
本文将介绍一些常见的单片机汇编指令,供大家参考和学习。
一、数据传输指令1. MOV 指令:将数据从一个存储器位置或寄存器传输到另一个存储器位置或寄存器。
例如:MOV A, B ;将B的值传送给A寄存器MOV R1, #20 ;将数值20传送给R1寄存器2. LDA 和 STA 指令:分别用于将数据从存储器加载到累加器和将累加器中的数据存储到存储器中。
例如:LDA 0x20 ;将地址为0x20的存储器单元的数据加载到累加器STA 0x30 ;将累加器中的数据存储到地址为0x30的存储器单元3. XCH 指令:用于交换两个存储器位置或寄存器的数据。
例如:XCH A, B ;交换A和B寄存器的值二、算术指令1. ADD 和 SUB 指令:分别用于将数据相加和相减。
例如:ADD A, B ;将A和B的值相加,并将结果存储到A寄存器SUB A, B ;将B的值从A中减去,并将结果存储到A寄存器2. INC 和 DEC 指令:分别用于将数据递增和递减。
例如:INC A ;将A的值递增1DEC A ;将A的值递减1三、逻辑指令1. AND、OR 和 XOR 指令:分别用于进行逻辑与、逻辑或和逻辑异或操作。
例如:AND A, B ;将A和B的值进行逻辑与操作,并将结果存储到A寄存器OR A, B ;将A和B的值进行逻辑或操作,并将结果存储到A寄存器XOR A, B ;将A和B的值进行逻辑异或操作,并将结果存储到A寄存器2. NOT 指令:用于对一个存储器位置或寄存器中的数据进行逻辑非操作。
一、数据传送类指令(8种助记符)MOV(英文为Move):对内部数据寄存器RAM和特殊功能寄存器SFR的数据进行传送;P55PUSH (Push onto Stack) 入栈;PUSH directPOP (Pop from Stack) 出栈;POP directXCH (Exchange) 字节交换;XCH A,源/@RiXCHD (Exchange low-order Digit) 低半字节交换;同上SWAP (Swap) 低4位与高4位交换;SWAP A MOVC(Move Code)读取程序存储器数据表格的数据传送;MOVC A,@A+DPTR/PC MOVX (Move External RAM) 对外部RAM的数据传送;MOVX @DPTR,A MOVX A,@DPTR/@Ri MOVX @Ri,A二、算术运算类指令(8种助记符)ADD(Addition) 加法;ADDC(Add with Carry) 带进位加法;INC(Increment) 加1;INC A/Rn/direct/@Ri/源/DPTRDA(Decimal Adjust) 十进制调整;SUBB(Subtract with Borrow) 带借位减法;DEC(Decrement) 减1;DEC A/Rn/direct/@Ri/源MUL(Multiplication、Multiply) 乘法;MUL AB 高B,低A。
Cy=0 大于256,OV=1 DIV(Division、Divide) 除法;DIV AB 商A,余B。
Cy=0 OV=B(同上)三、逻辑运算类指令(9种助记符)CLR(Clear) 清零;CLR ACPL(Complement) 取反;CPL ARL(Rotate left) 循环左移;(同上)RLC(Rotate Left throught the Carry flag) 带进位循环左移;(同上)RR(Rotate Right) 循环右移;(同上)RRC (Rotate Right throught the Carry flag) 带进位循环右移;(同上)ANL(AND Logic) 逻辑与;ANL A,#data/Rn/direct/@Ri ANL direct,A/#dataORL(OR Logic) 逻辑或;ORL A,#data/Rn/direct/@Ri ANL direct,A/#dataXRL(Exclusive-OR Logic) 逻辑异或;(同上)四、位操作指令(6种助记符)MOV 位数据传送指令;MOV C,bit MOV bit,CCLR 位清零;C bitSETB(Set Bit)位置1;C bitCPL位取反;(同上)ANL位逻辑运算指令;ANL C,bit//bitORL位逻辑或运算指令;(同上)五、控制转移类指令(18种助记符)AJMP(Absolute Jump)绝对转移;AJMP addr11/ LABELLJMP(Long Jump)长转移;(同上)SJMP(Short Jump)短转移;SJMP rel/ LABELJMP间接转移指令; JMP @A+DPTRJZ (Jump if Zero)结果为0则转移;JZ rel/ LABELJNZ (Jump if Not Zero) 结果不为0则转移;(同上)CJNE (Compare Jump if Not Equal)比较不相等则转移;CJNE A,direct,rel/ LABEL CJNE A/Rn/@Ri,#data,rel/ LABELJC (Jump if the Carry flag is set)有进位则转移;JC rel/ LABELJNC (Jump if Not Carry)无进位则转移;(同上)JB (Jump if the Bit is set)位为1则转移;JB bit, rel/ LABELJNB (Jump if the Bit is Not set) 位为0则转移;(同上)JBC(Jump if the Bit is set and Clear the bit) 为1则转移,并清除该位;DJNZ (Decrement Jump if Not Zero)减1后不为0则转移;DJNZ Rn,rel/ LABEL DJNZ direct,rel/ LABELLCALL(Long subroutine Call)子程序长16调用;LCALL addr16/ SUBROUTINEACALL(Absolute subroutine Call)子程序绝对11调用;(同上)RET(Return from subroutine)子程序返回;RETI(Return from Interruption)中断返回;NOP (No Operation) 空操作;8种常用伪指令1.ORG 16位地址;此指令用在原程序或数据块的开始,指明此语句后面目标程序或数据块存放的起始地址。
汇编伪指令注释:1、DS ---预留存储区命令格式:〔标号:〕 DS 表达式值其功能是从指定地址开始,定义一个存储区,以备源程序使用。
存储区预留的存储单元数由表达式的值决定。
TMP: DS 1从标号TEP地址处开始保留1个存储单元(字节)。
2、BIT---定义位命令格式:字符名称 BIT 位地址其功能用于给字符名称定义位地址。
SPK BIT P3.7经定义后,允许在指令中用SPK代替P3.7。
3、USING指令USING指令通知汇编器使用8051的哪一个工作寄存器组。
格式: USING 表达式(值必须为0-3,默认值为0。
)USING 0使用第0组工作寄存器。
4、SEGMENT指令SEGMENT 指令用来声明一个再定位段和一个可选的再定位类型。
格式:再定位段名 SEGMENT 段类型〔再定位类型〕其中,“再定位段名”用于指明所声明的段。
“段类型”用于指定所声明的段将处的存储器地址空间。
可用的段类型有 CODE、XDATA、DATA、IDATA和BIT。
STACK_SEG SEGMENT IDATADATA_SEG SEGMENT DATA5、RSEG---再定位段选择指令再定位段选择指令为RSEG,用于选择一个已在前面定义过的再定位段作为当前段。
格式: RSEG 段名段名必须是在前面已经声明过的再定位段。
DATA_SEG SEGMENT DATA ;声明一个再定位DATA段RSEG DATA_SEG ;选择前面声明的再定位DATA段作为当前段6、绝对段选择指令CSEG---绝对代码段DSEG---内部绝对数据段XSEG---外部绝对数据段ISEG ---内部间接寻址数据段BSEG---绝对位寻址数据段格式:CSEG [AT 绝对地址表达式]DSEG [AT 绝对地址表达式]XSEG [AT 绝对地址表达式]ISEG [AT 绝对地址表达式]BSEG [AT 绝对地址表达式]括号内是可选项,用来指定当前绝对段的基地址。
单片机指令功能一览表一,普通传送指令:1,以累加器A为目的的操作数指令MOV A,RnMOV A,directMOV A,@RiMOV A,#data2,以寄存器Rn为目的的操作数指令MOV Rn,AMOV Rn,dircetMOV Rn,#data3,以直接地址direct为目的的操作数指令MOV dircet,AMOV dircet,RnMOV dircet1,dircet2MOV dircet,@Ri ((Ri))→directMOV dircet,#data4,以间接地址(Ri)为目的的操作数指令MOV @Ri,A A→(Ri)MOV @Ri,direct direct→(Ri)MOV @Ri,#data #data→(Ri)5,16位数据传送指令MOV DPTR,#data16 dataH→DPH,dataL→DPL二,特殊传送指令:1,访问片外RAM的指令MOVX A,@Ri ((Ri))→AMOVX A,@DPTR ((DPTR))→AMOVX @Ri,A A→(Ri)MOVX @DPTR,A A→(DPTR)2,访问片内RAM的指令MOVC A,@A+DPTR 先PC+1→PC,后((A+PC))→A MOVC A,@A+PC 先PC+1→PC,后((A+DPTR))→A 4,堆栈操作指令PUSH dircet 先SP+1→SP,后(direct)→(SP)POP dircet 先((SP))→direct,后SP-1→SP5,数据交换指令XCH A,RnXCH A,dircetXCH A,@RiXCHD A,@RiSWAP A三,四则运算指令1,加法指令ADD A,Rn A+Rn→AADD A,dircet A+(direct) →A ADD A,@Ri A+((Ri)) →A ADD A,#data A+#data→A2,带进位加指令ADDC A,Rn A+Rn+CY→A ADDC A,dircet A+(direct) +CY→A ADDC A,@Ri A+((Ri)) +CY→A ADDC A,data A+#data+CY→A 3,带借位减法指令SUBB A,Rn A-Rn-CY→A SUBB A,dircet A-(direct) -CY→A SUBB A,@Ri A-((Ri)) -CY→A SUBB A,data A-#data-CY→A 4,乘法指令MUL AB四,特殊运算指令1,加1指令INC AINC RnINC dircetINC @RiINC DPTR2,减1指令DEC ADEC RnDEC dircetDEC @Ri3,十进制调整指令DA A五,逻辑运算指令1,与运算ANL A,RnANL A,dircetANL A,@RiANL A,#dataANL dircet AANL dircet,#data2,或运算ORL A,RnORL A,dircetORL A,@RiORL A,#dataORL dircet,AORL dircet,#data3,异或运算XRL A,RnXRL A,dircetXRL A,@RiXRL A,#dataXRL dircet ,AXRL dircet,#data4,累加器操作指令CLR A 累加器清零CPL A 累加器取反RL A A中的内容向左循环一位RLC A A中的内容带进位位C向左循环一位RR A A中的内容向右循环一位RRC A A中的内容带进位位C向右循环一位六,程序转移指令1,长转移指令LJMP addr16;先PC+3→PC,后addr16→PC2,短转移指令AJMP addr11; 先PC+2→PC,后addr11→PC10~0 ,PC15~11 3,相对转移指令SJMP rel 先PC+2→PC,后PC+rel→PC4,相对长转移指令JMP @A+DPTR A+DPTR→PC5,累加器内容判0转移JZ relJNZ rel6,两操作数比较不相等转移CJNE A,dircet,relCJNE A,#data,relCJNE A,Rn,#data,rel B8~BF data rel CJNE @Ri,#data,rel B6~B7 data rel7,循环转移指令DJNZ Rn,rel D8~DF rel DJNZ dircet,rel B5 dircet rel七,子程序调用和返回指令1,短调子指令ACALL addr 112,长调子指令LCALL addr 163,返回指令RETRETI4,空操作指令NOP PC+1→PC 八,位操作指令1,位传送指令MOV C,bitMOV bit,C2,位置1指令SETB CSETB bit3,位清零指令CLR CCLR bit4,位取反指令CPL CCPL bit5,位逻辑“与”指令ANL C,bitANL C,/bit6,位逻辑“或”指令ORL C,bitORL C,/bit7,判C转移指令JC relJNC rel8,判位变量转移指令JB bit,relJNB bit,rel9,判位变量并清零转移指令JBC bit,rel。
单片机汇编指令单片机汇编指令:为解决某些特定的问题代码中必须嵌入汇编语言以代替C语言完成的单片机的编程,汇编语言对于程序调试是不可或缺的。
它包括:数据传送类指令,算术运算类指令,逻辑运算与循环类指令,控制转移类指令,位操作(布尔操作)类指令。
现在单片机的编程大多是C语言完成但有时代码中必须嵌入汇编语言解决某些特定的问题,对于程序调试汇编语言更是不可或缺一.数据传送类指令:(1)一般传送指令:①8位传送:1 MOV A,Rn ;A←(Rn):寄存器内容送入累加器2 MOV A,direct ;A←(direct):直接地址单元中的数据送入累加器3 MOV A,@Ri ;A←((Ri)):间接RAM 中的数据送入累加器4 MOV A,#data ;A←(data):立即数送入累加器5 MOV Rn,A ;Rn←(A):累加器内容送入寄存器6 MOV Rn,direct ;Rn←(direct):直接地址单元中的数据送入寄存器7 MOV Rn,#data ;Rn←(data):立即数送入寄存器8 MOV direct,A ;direct←(A):累加器内容送入直接地址单元9 MOV direct,Rn ;direct←(Rn):寄存器内容送入直接地址单元10 MOV direct,direct;direct←(direct):直接地址单元中的数据送入另一个直接地址单元11 MOV direct,@Ri ;direct←(@Ri):间接RAM 中的数据送入直接地址单元12 MOV direct,#data ;direct←(data):立即数送入直接地址单元13 MOV @Ri,A;Ri←(A):累加器内容送入间接RAM 单元14 MOV @Ri,direct ;Ri←(direct)直接地址单元数据送入间接RAM 单元15 MOV @RI,#data ;Ri←(data):立即数送入间接RAM 单元②16位传送:16 MOV DRTR,#data16 ;(DRTR) ←(data16):16 位立即数送入地址寄存器(2)特殊传送指令:⑤①读取常数表:17 MOVC A,@A+DPTR ;A←((A)+(DPTR)):以DPTR为基地址变址寻址单元中的数据送入累加器18 MOVC A,@A+PC;A←((A)+(PC)):以PC 为基地址变址寻址单元中的数据送入累加器②读写片外RAM及接口单元数据:读片外RAM:19 MOVX A,@Ri ;A←((Ri)):外部RAM(8 位地址)送入累加器20 MOVX A,@DPTR ;A←((DPTR)):外部RAM(16 位地址)送入累加器写片外RAM:21 MOVX @Ri,A ; (Ri)←(A):累计器送外部RAM(8 位地址)22 MOVX @DPTR,A ;(DPTR)←(A):累计器送外部RAM(16 位地址)③堆栈操作指令:23 PUSH direct;SP←(SP),(SP)←(direct)直接地址单元中的数据压入堆栈24 POP direct ;(direct)←((SP)), SP←(SP)-1:弹栈送直接地址单元④数据交换指令:字节交换:25 XCH A,Rn ;(A)←→(Rn):寄存器与累加器交换26 XCH A,direct ;(A)←→(direct):直接地址单元与累加器交换27 XCH A,@Ri; (A)←→(Ri):间接RAM 与累加器交换半字节交换:28 XCHD A,@Ri ;((Ri).3~(Ri).0) ←→(ACC.3~ACC.0):间接RAM 的低半字节与累加器的弟半字节交换29 SWAP A ;(ACC.7~ACC.4)←→(ACC.3~ACC.0):累加器的高低4位互换二.算术运算类指令:(1)不带进位加法:1 ADD A,Rn ;A←(A)+(Rn):寄存器内容加到累加器2 ADD A,direct;A←(A)+(direct):直接地址单元的内容加到累加器3 ADD A,@Ri;A←(A)+((Ri)):间接ROM 的内容加到累加器4 ADD A,#data;A←(A)+ data:立即数加到累加器(2)带进位加法:5 ADDC A,Rn ;A←(A)+(Rn)+(CY):寄存器内容带进位加到累加器6 ADDC A,direct;A←(A)+(direct)+(CY):直接地址单元的内容带进位加到累加器7 ADDC A,@Ri ;A←(A)+((Ri))+(CY):间接ROM 的内容带进位加到累加器8 ADDC A,#data;A←(A)+ data+(CY):立即数带进位加到累加器(3)加1:9 INC A;A←(A)+1:累加器加110 INC Rn;A←(Rn)+1:寄存器加111 INC direct;A←(direct)+1:直接地址单元加112 INC @Ri;(Ri)←((Ri))+1:间接RAM 单元加113 INC DPTR;DPTR←(DPTR)+1:地址寄存器DPTR 加 1(4)十进制调整:DA A;调整A的内容为正确的BCD码(5)带借位减法:14 SUBB A,Rn ;A←(A)-(Rn)-(CY):累加器带借位减寄存器内容15 SUBB A,direct;A←(A)-(direct)-(CY):累加器带借位减直接地址单元的内容16 SUBB A,@Ri ;A←(A)-(Ri)-(CY):累加器带借位减间接RAM 中的内容17 SUBB A,#data ;A←(A)-data-(CY):累加器带借位减立即数(6)减1:18 DEC A ;A←(A)-1:累加器减119 DEC Rn ;A←(Rn)-1:寄存器减120 DEC direct ;A←(direct)-1:直接地址单元减121 DEC @Ri;A←(Ri)-1:间接RAM 单元减 1(7)乘法:22 MUL AB;累加器A与寄存器B相乘(乘积的低8位存在A中,高8位存在B中)(8)乘法:23 DIV AB;累加器A除以寄存器B (商的整数部分存放在A中,余数存在B中)三.逻辑运算与循环类指令:(1)逻辑与:1 ANL A,Rn; A←(A)∧(Rn) :累加器与寄存器相“与”2 ANL A,direct;A←(A)∧(direct):累加器与直接地址单元相“与”3 ANL A,@Ri; A←(A)∧(Ri):累加器与间接RAM 单元相“与”4 ANL A,#data;A←(A)∧data:累加器与立即数相“与”5 ANL direct,A;direct←(direct)∧(A):直接地址单元与累加器相“与”6 ANL direct,#data;direct←(direct)∧data:直接地址单元与立即数相“与”(2)逻辑或:7 ORL A,Rn ;A←(A)∨(Rn):累加器与寄存器相“或”8 ORL A,direct ;A←(A)∨(direct):累加器与直接地址单元相“或”9 ORL A,@Ri;A←(A)∨(Ri):累加器与间接RAM 单元单元相“或”10 ORL A,#data;A←(A)∨data:累加器与立即数相“或”11 ORL direct,A;direct←(direct)∨(A):直接地址单元与累加器相“或”12 ORL direct,#data;direct←(direct)∨data:直接地址单元与立即数相“或”(3)逻辑或与:13 XRL A,Rn; A←(A)⊕(Rn) :累加器与寄存器相“异或”14 XRL A,direct;A←(A)⊕ (direct):累加器与直接地址单元相“异或”15 XRL A,@Ri; A←(A)⊕ (Ri):累加器与间接RAM 单元单元相“异或”16 XRL A,#data;A←(A)⊕data:累加器与立即数相“异或”17 XRL direct,A;direct←(direct)⊕(A):直接地址单元与累加器相“异或”18 XRL direct,#data;direct←(direct)⊕data:直接地址单元与立即数相“异或”(4)累加器清0或取反:19 CLR A;A←0:累加器清“0”(5)累加器循环移位:21 RL A ;1~7A ←(0~6A ),0A ←(7A ):累加器循环左移22 RLC A ;CY ←(7A ),1~7A ←(0~6A ),0A ←(CY ):累加器带进位位循环左移 23 RR A ;1~7A →(0~6A ),0A →(7A ):累加器循环右移24 RRC A ;CY →(7A ),1~7A →(0~6A ),0A →(CY ):累加器带进位位循环右移四.控制转移类指令:(1)无条件转移:1 AJMP addr11 ;PC ←(PC)+2,P 0~10C ←addr11:绝对(短)转移2 LJMP addr16;PC ←addr16:长转移3 SJMP rel ;PC ←(PC)+2,PC ←(PC)+rel :相对转移4 JMP @A+DPTR ;PC ←(PC)+1,PC ←(A)+(DPTR):相对于DPTR 的间接转移(散转移)(2)条件转移:①累加器判0转移:5 JZ rel ;若(A)=0,则PC ←(PC)+rel :累加器为零转移6 JNZ rel ;若(A)≠0,则PC ←(PC)+rel :累加器不为零转移②比较不相等转移:7 CJNE rel 累加器非零转移8 CJNE A,direct,rel ;累加器与直接地址单元比较,不相等则转移9 CJNE A,#data,rel 累加器与立即数比较,不相等则转移10 CJNE Rn,#data,rel 寄存器与立即数比较,不相等则转移11 CJNE @Ri,#data,rel 间接RAM 单元与立即数比较,不相等则转移 ③减1不为0转移:12 DJNZ Rn,rel ;寄存器减1,非零转移13 DJNZ direct, rel ;直接地址单元减1,非零转移(3)调用与返回:①调用:14 ACALL addr11;绝对(短)调用子程序15 LCALL addr16;长调用子程序 ②返回16 RET ;子程序返回17 RETI ;中断服务子程序返回(4)空做操:18 NOP ;空操作五.位操作(布尔操作)类指令:(1)位传送:11 MOV C,bit ;bit←(CY):直接地址位送入进位位12 MOV bit,C ;CY←(bit):进位位送入直接地址位(2)位状态设置:①位清0:1 CLR C ;CY←0:清进位位2 CLR bit;bit←0:清直接地址位②位置位:3 SETB C;CY←1:置进位位4 SETB bit;bit←1:置直接地址位(3)位逻辑运算:①位逻辑与:7 ANL C,bit;进位位和直接地址位相“与”8 ANL C,/bit;进位位和直接地址位的反码相“与”②位逻辑或:9 ORL C,bit;进位位和直接地址位相“或”10 ORL C,/bit;进位位和直接地址位的反码相“或”③位取反:5 CPL C;CY←(CY):进位位求反6 CPL bit;bit←(bit):置直接地址位求反(4)位判跳(条件转移):①判CY转移:13 JC rel;若(CY)=1,PC←(PC)+2+rel,否则顺次执行:进位位为1 则转移14 JNC rel;若(CY)=0,PC←(PC)+2+rel,否则顺次执行:进位位为0 则转移②判bit转移:15 JB bit,rel;(bit)=1,PC←(PC)+3+rel,否则顺次执行:直接地址位为1 则转移16 JBC bit,rel;(bit)=1,PC←(PC)+3+rel,并使bit←0,否则顺次执行:直接地址位为0 则转移17 JNB bit,rel;(bit)=0,PC←(PC)+3+rel,否则顺次执行:直接地址位为1 则转移,该位清零。
51单片机指令表汇总51 单片机是一种广泛应用于电子工程和嵌入式系统开发的微控制器。
要熟练掌握 51 单片机的编程,了解其指令表是至关重要的。
下面就为大家汇总一下 51 单片机的常见指令。
数据传送类指令MOV 指令:这是最基本的数据传送指令,用于在寄存器之间、寄存器与存储器之间传送数据。
例如,“MOV A, 50H”就是将立即数 50H传送到累加器 A 中。
MOVX 指令:用于在片外数据存储器和累加器 A 之间进行数据传送。
比如“MOVX A, @DPTR”,将片外数据存储器中由数据指针 DPTR 所指定单元的内容传送到累加器 A 中。
MOVC 指令:用于访问程序存储器中的数据表格。
“MOVC A, @A+DPTR”是常见的用法。
算术运算类指令ADD 指令:实现加法运算。
像“ADD A, R0”就是将累加器 A 的内容和寄存器 R0 的内容相加,结果存放在累加器 A 中。
ADDC 指令:带进位加法指令。
考虑了上一次运算产生的进位标志。
SUBB 指令:用于减法运算,并且会考虑借位标志。
逻辑运算类指令ANL 指令:进行逻辑与操作。
例如“ANL A, R0”,将累加器 A 和寄存器 R0 的内容进行逻辑与运算,结果存放在累加器 A 中。
ORL 指令:执行逻辑或操作。
XRL 指令:实现逻辑异或运算。
控制转移类指令JC 指令:若进位标志为 1 则跳转。
JZ 指令:若累加器 A 的内容为 0 则跳转。
LJMP 指令:长跳转指令,可以跳转到 64KB 程序存储器空间的任意位置。
位操作类指令SETB 指令:将指定的位设置为 1。
例如“SETB P10”,将 P1 端口的第 0 位置 1。
CLR 指令:把指定的位清零。
这些只是 51 单片机指令的一部分,实际应用中还有更多的指令和组合使用方式。
在编程时,合理选择和运用这些指令能够实现各种复杂的功能。
比如,通过数据传送指令来初始化变量和读取外部数据;利用算术运算指令进行数值计算;借助逻辑运算指令处理逻辑关系;使用控制转移指令实现程序的分支和循环;运用位操作指令控制单个引脚的状态。
常用单片机汇编指令:MOV:单片机内部的寄存器或者存储器之间相互传递数据(内部RAM);MOVX:单片机内部的A累加器与片外的数据存储器(片外RAM)传送数据. MOVC: 单片机内部的A累加器向ROM(程序存储器)读取数据,因为程序存储器是固定的不可以写的,所以,A只能读数据,却不能向它写数据;换句话说MOVX和MOVC是针对两种不同的存储器而言,一个是片外数据存储器,另一个却是程序存储器1 .MOV A,Rn 寄存器内容送入累加器2 .MOV A,direct 直接地址单元中的数据送入累加器3 .MOV A,@Ri (i=0,1)间接RAM 中的数据送入累加器4 .MOV A,#data 立即数送入累加器5 .MOV Rn,A 累加器内容送入寄存器6 .MOV Rn,direct 直接地址单元中的数据送入寄存器7 .MOV Rn,#data 立即数送入寄存器8 .MOV direct,A 累加器内容送入直接地址单元9 .MOV direct,Rn 寄存器内容送入直接地址单元10. MOV direct,direct 直接地址单元中的数据送入另一个直接地址单元11 .MOV direct,@Ri (i=0,1)间接RAM 中的数据送入直接地址单元12 .MOV direct,#data 立即数送入直接地址单元13 .MOV @Ri,A (i=0,1)累加器内容送间接RAM 单元14 .MOV @Ri,direct (i=0,1)直接地址单元数据送入间接RAM 单元15 .MOV @Ri,#data (i=0,1)立即数送入间接RAM 单元16 .MOV DPTR,#data16 16 位立即数送入地址寄存器17 .MOVC A,@A+DPTR 以DPTR为基地址变址寻址单元中的数据送入累加器18 .MOVC A,@A+PC 以PC 为基地址变址寻址单元中的数据送入累加器19 .MOVX A,@Ri (i=0,1)外部RAM(8 位地址)送入累加器20 .MOVX A,@DPTR 外部RAM(16 位地址)送入累加器21 .MOVX @Ri,A (i=0,1)累计器送外部RAM(8 位地址)22 .MOVX @DPTR,A 累计器送外部RAM(16 位地址)23 .PUSH direct 直接地址单元中的数据压入栈24 .POP direct 弹栈送直接地址单元25 .XCH A,Rn 寄存器与累加器交换26 .XCH A,direct 直接地址单元与累加器交换27 .XCH A,@Ri (i=0,1)间接RAM 与累加器交换28 .XCHD A,@Ri (i=0,1)间接RAM 的低半字节与累加器交换算术操作类指令:1. ADD A,Rn 寄存器内容加到累加器2 .ADD A,direct 直接地址单元的内容加到累加器3 .ADD A,@Ri (i=0,1)间接ROM 的内容加到累加器4 .ADD A,#data 立即数加到累加器5 .ADDC A,Rn 寄存器内容带进位加到累加器6 .ADDC A,direct 直接地址单元的内容带进位加到累加器7 .ADDC A,@Ri(i=0,1) 间接ROM 的内容带进位加到累加器8 .ADDC A,#data 立即数带进位加到累加器9 .SUBB A,Rn 累加器带借位减寄存器内容10. SUBB A,direct 累加器带借位减直接地址单元的内容11 .SUBB A,@Ri (i=0,1)累加器带借位减间接RAM 中的内容12 .SUBB A,#data 累加器带借位减立即数13 .INC A 累加器加114 .INC Rn 寄存器加115 .INC direct 直接地址单元加116 .INC @Ri (i=0,1)间接RAM 单元加117 .DEC A 累加器减118 .DEC Rn 寄存器减119 .DEC direct 直接地址单元减120 .DEC @Rj 间接RAM 单元减 121 .INC DPTR 地址寄存器DPTR 加 122 .MUL AB A 乘以B,结果放在A23 .DIV AB A 除以B,结果放在A24. DA A 累加器十进制调整布尔变量操作类指令:1. CLR C 清进位位2 .CLR bit 清直接地址位3 .SETB C 置进位位4 .SETB bit 置直接地址位5 .CPL C 进位位求反6 .CPL bit 置直接地址位求反7 .ANL C,bit 进位位和直接地址位相“与”8 .ANL C,bit 进位位和直接地址位的反码相“与”9 .ORL C,bit 进位位和直接地址位相“或”10. ORL C,bit 进位位和直接地址位的反码相“或”11 .MOV C,bit 直接地址位送入进位位12 .MOV bit,C 进位位送入直接地址位13 .JC rel 进位位为1 则转移14 .JNC rel 进位位为0 则转移15 .JB bit,rel 直接地址位为1 则转移16 .JNB bit,rel 直接地址位为0 则转移17 .JBC bit,rel 直接地址位为1 则转移,该位清零逻辑操作数指令:1. ANL A,Rn 累加器与寄存器相“与”2 .ANL A,direct 累加器与直接地址单元相“与”3 .ANL A,@Ri 累加器与间接RAM 单元相“与”4 .ANL A,#data 累加器与立即数相“与”5 .ANL direct,A 直接地址单元与累加器相“与”6 .ANL direct,#data 直接地址单元与立即数相“与”7 .ORL A,Rn 累加器与寄存器相“或”8 .ORL A,direct 累加器与直接地址单元相“或”9 .ORL A,@Ri 累加器与间接RAM 单元单元相“或”10. ORL A,#data 累加器与立即数相“或”11. ORL direct,A 直接地址单元与累加器相“或”12 .ORL direct,#data 直接地址单元与立即数相“或”13 .XRL A,Rn 累加器与寄存器相“异或”14 .XRL A,direct 累加器与直接地址单元相“异或”15 .XRL A,@Ri 累加器与间接RAM 单元单元相“异或”16 .XRL A,#data 累加器与立即数相“异或”17 .XRL direct,A 直接地址单元与累加器相“异或”18 .XRL direct,#data 直接地址单元与立即数相“异或”19 .CLR A 累加器清“0”20 .CPL A 累加器求反21 .RL A 累加器循环左移22 .RLC A 累加器带进位位循环左移23 .RR A 累加器循环右移24 .RRC A 累加器带进位位循环右移25 .SWAP A 累加器半字节交换控制转移类指令1. ACALL addr11 绝对(短)调用子程序2 .LCALL addr16 长调用子程序3 .RET 子程序返回4 .RETI 中断返回5 .AJMP addr11 绝对(短)转移6 .LJMP addr16 长转移7 .SJMP rel 相对转移8 .JMP @A+DPTR 相对于DPTR 的间接转移9. JZ rel 累加器为零转移10. JNZ rel 累加器非零转移11. CJNE A,direct,rel 累加器与直接地址单元比较,不相等则转移12 .CJNE A,#data,rel 累加器与立即数比较,不相等则转移13 .CJNE Rn,#data,rel 寄存器与立即数比较,不相等则转移14 .CJNE @Ri,#data,rel 间接RAM 单元与立即数比较,不相等则转移15 .DJNZ Rn,rel 寄存器减1,非零转移16 .DJNZ direct,erl 直接地址单元减1,非零转移17 .NOP 空操作。