【可直接使用】单片机指令表(最全).doc

合集下载

单片机指令大全

单片机指令大全

引言概述:单片机指令是嵌入式系统设计中至关重要的一部分,它们定义了单片机的功能和操作。

本文是单片机指令大全系列的第二部分,旨在提供更多全面的单片机指令信息,帮助读者更好地理解和应用单片机指令。

正文内容:一、移位指令1.逻辑左移指令:将操作数的每一位向左移动一位,并且最低位填充0。

2.逻辑右移指令:将操作数的每一位向右移动一位,并且最高位填充0。

3.算术右移指令:将操作数的每一位向右移动一位,并且最高位保持不变。

4.循环左移指令:将操作数的每一位向左循环移动一位,即最高位移动到最低位。

5.循环右移指令:将操作数的每一位向右循环移动一位,即最低位移动到最高位。

二、逻辑运算指令1.逻辑与指令:对操作数进行逻辑与运算,将两个二进制数对应位上的值进行逻辑与操作。

2.逻辑或指令:对操作数进行逻辑或运算,将两个二进制数对应位上的值进行逻辑或操作。

3.逻辑非指令:对操作数进行逻辑非运算,将二进制数的每一位取反。

4.逻辑异或指令:对操作数进行逻辑异或运算,将两个二进制数对应位上的值进行逻辑异或操作。

5.逻辑移位指令:将操作数进行逻辑左移或右移。

三、算术运算指令1.加法指令:对操作数进行加法运算,并将运算结果保存到指定的寄存器或存储器中。

2.减法指令:对操作数进行减法运算,并将运算结果保存到指定的寄存器或存储器中。

3.乘法指令:对操作数进行乘法运算,并将运算结果保存到指定的寄存器或存储器中。

4.除法指令:对操作数进行除法运算,并将运算结果保存到指定的寄存器或存储器中。

5.移位指令:对操作数进行移位运算,包括算术左移、算术右移、循环左移和循环右移。

四、输入输出指令1.读取输入指令:从指定的输入设备读取数据,并将数据保存到指定的寄存器或存储器中。

2.输出显示指令:将指定的数据从寄存器或存储器中读取,并显示到指定的输出设备上。

3.端口输入指令:从指定的端口读取数据,并将数据保存到指定的寄存器或存储器中。

4.端口输出指令:将指定的数据从寄存器或存储器中读取,并输出到指定的端口上。

完整word版单片机指令表最全

完整word版单片机指令表最全

单片机指令以A开头的指令有18条,分别为:7、ADDC A,direct指令名称:直接寻址带进位加法指令指令代码:35H指令功能:累加器内容、内部RAM低128单元或专用寄存器内1、ACALL addr11容与进位位加指令名称:绝对调用指令操作内容:A←(A)+(direct)+(C)指令代码:A10 A9 A8 10001 A7 A6 A5 A4 A3 A2 A1 A0字节数:2 指令功能:构造目的地址,进行子程序调用。

其方法是以指令提机器周期:1影响标志位:C,11供的11位地址(al0~a0),取代PC的低位,PC的高5位不变。

AC,OV操作内容:SP←(SP)+1PC←(PC)+2 8、ADDC A,@RiSP←(SP)+10 ~(SP)←(PC)7指令名称:间接寻址带进位加法指令指令代码:36H~37H0 ~~0←addrl0 (SP)←(PC)15~8 PC10指令功能:累加器内容, 内部RAM低128单元内容及进位位相加操作内容:A←(A)+((Ri))+(C)2 字节数:机器周期:2,i=0,1字节数:1 机器周期:位,使用说明:由于指令只给出子程序入口地址的低11因此调用1影响标志位:C,AC,OV范围是2KB。

9、ADDC A,、2ADD A,Rn#data指令名称:立即数带进位加法指令2FH指令代码:28H~指令代码:34H指令名称:寄存器加法指令指令功能:累加器内容、立即数及进位位相加指令功能:累加器内容与寄存器内容相加操作内容:A←(A)+(Rn)操作内容:,nA←(A)+data+(C) =0~7字节数:机器周期;12 机器周期:1字节数:1影响标志位:C影响标志位:,AC,C,AC,OVOV10、AJMP addr11 ADD A3、,direct指令名称:绝对转移指令指令代码:25H指令名称:直接寻址加法指令指令代码:RAM指令功能:累加器内容与内部单元或专用寄存器内容相加A10 A9 A8 1 0 0 0 1 A7 A6 A5 A4 A3 A2 A1 A0 指令功能:构造目的地址,实现程序转移。

单片机汇编指令表

单片机汇编指令表
A Rn direct @Ri DPTR A Rn direct @Ri AB AB A A,Rn A,direct A,@Ri A,#data A,Rn A,direct A,@Ri A,#data A,Rn A,direct A,@Ri A,#data
指令说明 (数据传递类指令)
寄存器传送到累加器 直接地址传送到累加器 累加器传送到外部RAM(8 地址) 立即数传送到累加器 累加器传送到寄存器 直接地址传送到寄存器 累加器传送到直接地址 寄存器传送到直接地址 直接地址传送到直接地址 累加器传送到直接地址 间接RAM 传送到直接地址 立即数传送到直接地址 直接地址传送到直接地址 直接地址传送到间接RAM 立即数传送到间接RAM 16 位常数加载到数据指针 代码字节传送到累加器 代码字节传送到累加器 外部RAM(8 地址)传送到累加器 外部RAM(16 地址)传送到累加器 累加器传送到外部RAM(8 地址) 累加器传送到外部RAM(16 地址) 直接地址压入堆栈 直接地址弹出堆栈 寄存器和累加器交换 直接地址和累加器交换 间接RAM 和累加器交换 间接RAM 和累加器交换低4 位字节
1
1
2
1
1
1
2
1
2
1
3
2
1
2
2
1
1
1
2
1
2
1
3
1
1
2
2
1
1
1
2
1
2
1
3
1
1
2
1
1
1
1
1
1
1
1
1
1
1
1
1
2
2
2
2

单片机指令大全

单片机指令大全

单片机指令大全数据传递指令:(3)以直接地址为目的操作数的指令MOV direct,A例:MOV 20H,AMOV direct,Rn MOV 20H,R1MOV direct1,direct2 MOV 20H,30HMOV direct,@Ri MOV 20H,@R1MOV direct,#data MOV 20H,#34H(4)以间接地址为目的操作数的指令MOV @Ri,A 例:MOV @R0,AMOV @Ri,direct MOV @R1,20HMOV @Ri,#data MOV @R0,#34H(5)十六位数的传递指令MOV DPTR,#data168051是一种8位机,这是唯一的一条16位立即数传递指令,其功能是将一个16位的立即数送入DPTR中去。

其中高8位送入DPH,低8位送入DPL。

例:MOV DPTR,#1234H,则执行完了之后DPH中的值为12H,DPL中的值为34H。

反之,如果我们分别向DPH,DPL送数,则结果也一样。

如有下面两条指令:MOV DPH,#35H,MOV DPL,#12H。

则就相当于执行了MOV DPTR,#3512H。

单片机的累加器A与片外RAM之间的数据传递类指令MOVX A,@RiMOVX @Ri,AMOVX A,@DPTRMOVX @DPTR,A说明:1)在51系列单片机中,与外部存储器RAM打交道的只能是A累加器。

所有需要传送入外部RAM的数据必需要通过A送去,而所有要读入的外部RAM中的数据也必需通过A 读入。

在此我们能看出内外部RAM的区别了,内部RAM间能直接进行数据的传递,而外部则不行,比如,要将外部R AM中某一单元(设为0100H单元的数据)送入另一个单元(设为0200H单元),也必须先将0100H单元中的内容读入A,然后再传送到0200H单元中去。

要读或写外部的RAM,当然也必须要知道RAM的地址,在后两条单片机指令中,地址是被直接放在DPTR中的。

单片机指令大全

单片机指令大全

单片机指令大全
指令格式功能简述字节数周期一、数据传送类指令
MOV A, Rn 寄存器送累加器 1 1 MOV Rn,A 累加器送寄存器 1 1 MOV A ,@Ri 内部RAM单元送累加器 1 1 MOV @Ri ,A 累加器送内部RAM单元 1 1 MOV A ,#data 立即数送累加器 2 1 MOV A ,direct 直接寻址单元送累加器 2 1 MOV direct ,A 累加器送直接寻址单元 2 1 MOV Rn,#data 立即数送寄存器 2 1 MOV direct ,#data 立即数送直接寻址单元 3 2 MOV @Ri ,#data 立即数送内部RAM单元 2 1 MOV direct ,Rn 寄存器送直接寻址单元 2 2 MOV Rn ,direct 直接寻址单元送寄存器 2 2 MOV direct ,@Ri 内部RAM单元送直接寻址单元 2 2 MOV @Ri ,direct 直接寻址单元送内部RAM单元 2 2 MOV direct2,direct1 直接寻址单元送直接寻址单元 3 2 MOV DPTR ,#data16 16位立即数送数据指
针 3 2
MOVX A ,@Ri 外部RAM单元送累加器(8位地
址) 1 2。

单片机指令大全(一)

单片机指令大全(一)

单片机指令大全(一)引言概述:本文是关于单片机指令的大全,主要介绍了单片机指令的基本概念和应用。

单片机指令是单片机操作的核心,具有重要的意义。

本文将按照不同的功能对单片机指令进行分类和阐述,为读者提供一份全面而简明的单片机指令资料。

正文:一、数据传送相关指令1. mov指令:用于将数据从一个寄存器传送到另一个寄存器2. ldi指令:用于将立即数存入寄存器3. ld指令:用于将存储器中的数据传送到寄存器4. st指令:用于将寄存器中的数据传送到存储器5. push和pop指令:用于将数据存入和取出堆栈二、算术运算指令1. add指令:用于将两个寄存器中的数据相加2. sub指令:用于将一个寄存器中的数据减去另一个寄存器中的数据3. inc和dec指令:用于将一个寄存器中的数据递增或递减4. mul和div指令:用于进行乘法和除法运算5. clr指令:用于将一个寄存器中的数据清零三、逻辑运算指令1. and指令:用于对两个寄存器中的数据进行按位与运算2. or指令:用于对两个寄存器中的数据进行按位或运算3. xor指令:用于对两个寄存器中的数据进行按位异或运算4. not指令:用于对一个寄存器中的数据进行取反运算5. test指令:用于对寄存器数据进行测试四、跳转指令1. jmp指令:用于无条件跳转到指定的地址2. jc、jnc、jz、jnz指令:用于根据特定条件进行跳转3. call和ret指令:用于子程序调用和返回4. cmp指令:用于比较两个寄存器中的数据5. loop指令:用于循环执行指定次数的程序五、I/O操作指令1. in指令:用于输入外设数据到寄存器中2. out指令:用于将寄存器中的数据输出到外设3. stc和clc指令:用于设置和清除进位标志位4. ei和di指令:用于开启和关闭中断5. hlt指令:用于控制单片机暂停执行总结:本文介绍了单片机指令的基本概念和分类,并详细阐述了每类指令的具体功能和使用方法。

单片机指令大全(二)2024

单片机指令大全(二)2024

单片机指令大全(二)引言概述:本文是关于单片机指令大全的第二部分。

在上一部分中,我们介绍了一些常用的单片机指令和其功能。

本文将继续介绍更多的单片机指令,包括数据传输、逻辑运算、算术运算、位操作以及状态寄存器等方面的指令。

这些指令将帮助您更好地理解和使用单片机。

1. 数据传输指令1.1. MOV指令:将一个数据从源操作数传送到目的操作数。

1.2. LDI指令:将一个立即数传送到一个寄存器。

1.3. LDS和STS指令:将数据从SRAM传送到寄存器或将寄存器的数据传送到SRAM。

1.4. IN和OUT指令:将数据从端口传送到寄存器或从寄存器传送到端口。

2. 逻辑运算指令2.1. AND、OR和XOR指令:进行逻辑与、逻辑或和逻辑异或运算。

2.2. NOT指令:对一个寄存器的数据进行逻辑非运算。

2.3. CLR指令:将一个寄存器的数据清零。

3. 算术运算指令3.1. ADD和SUB指令:对两个操作数进行加法或减法运算。

3.2. INC和DEC指令:对一个寄存器的数据进行加1或减1操作。

3.3. MUL和DIV指令:进行乘法和除法运算。

4. 位操作指令4.1. ANDI、ORI和XORI指令:对一个寄存器的数据进行与、或和异或运算。

4.2. SBI和CBI指令:设置或清除一个I/O端口的某个位。

4.3. SBIC和SBIS指令:跳转指令,根据指定的I/O端口位是否被设置或清除执行跳转操作。

5. 状态寄存器相关指令5.1. SEI和CLI指令:设置或清除全局中断。

5.2. SREG指令:用于保存和恢复状态寄存器的值。

5.3. IJMP和EIJMP指令:用于从程序中直接跳转到任意存储器位置。

总结:本文介绍了单片机指令大全的第二部分内容,包括数据传输、逻辑运算、算术运算、位操作以及状态寄存器等方面的指令。

这些指令的功能与用法将有助于您更好地理解和应用单片机。

通过熟练掌握这些指令,您将能够更加灵活地进行单片机程序的设计与开发。

(完整版)单片机指令大全

(完整版)单片机指令大全

一个单片机所需执行指令的集合即为单片机的指令系统。

单片机使用的机器语言、汇编语言及高级语言,但不管使用是何种语言,最终还是要“翻译”成为机器码,单片机才能执行之。

现在有很多半导体厂商都推出了自己的单片机,单片机种类繁多,品种数不胜数,值得注意的是不同的单片机它们的指令系统不一定相同,或不完全相同。

但不管是使用机器语言、汇编语言还是高级语言都是使用指令编写程序的。

所谓机器语言即指令的二进制编码,而汇编语言则是指令的表示符号。

在指令的表达式上也不会直接使用二进制机器码,最常用的是十六进制的形式。

但单片机并不能直接执行汇编语言和高级语言,都必须通过汇编器“翻译”成为二进制机器码方能执行,但如果直接使用二进制来编写程序,那将十分不便,也很难记忆和识别,不易编写、难于辨读,极易出错,同时出错了也相当难查找。

所以现在基本上都不会直接使用机器语言来编写单片机的程序。

最好的办法就是使用易于阅读和辨认的指令符号来代替机器码,我们常称这些符号为助记符,用助记符的形式表示的单片机指令就是汇编语言,为便于记忆和阅读,助记符号通常都使用易于理解的英文单词和拼音字母来表示。

每种单片机都有自己独特的指令系统,那么指令系统是开发和生产厂商定义的,如要使用其单片机,用户就必须理解和遵循这些指令标准,要掌握某种(类)单片机,指令系统的学习是必须的。

MCS-51共有111条指令,可分为5类:[1].数据传送类指令(共29条)[2].算数运算类指令(共24条)[3].逻辑运算及移位类指令(共24条)[4].控制转移类指令(共17条)[5].布尔变量操作类指令(共17条)一些特殊符号的意义在介绍指令系统前,我们先了解一些特殊符号的意义,这对今后程序的编写都是相当有用的。

Rn——当前选中的寄存器区的8个工作寄存器R0—R7(n=0-7)。

Ri——当前选中的寄存器区中可作为地址寄存器的两个寄存器R0和R1(i=0,1)direct—内部数据存储单元的8位地址。

单片机的指令表(最全)

单片机的指令表(最全)

单片机的指令表(最全)单片机的指令表(最全)在单片机编程中,指令表是编程过程中不可或缺的重要参考资料。

它包含了单片机的指令集,能够帮助程序员清晰地了解和使用不同的指令,以实现特定的功能。

本文将为您详细介绍单片机的指令表,包括指令的分类、常用指令的功能及应用示例。

1. 指令表的分类单片机的指令表根据指令的功能和执行方式进行分类。

常见的分类方式有:数据传送指令、算数运算指令、逻辑运算指令、条件跳转指令和无条件跳转指令等。

1.1 数据传送指令数据传送指令用于在寄存器之间传送数据,常见的指令有MOV、LDA、STA等。

例如,MOV指令可以将数据从一个寄存器传送到另一个寄存器。

1.2 算数运算指令算数运算指令用于进行加法、减法、乘法和除法等数值计算操作,常见的指令有ADD、SUB、MUL、DIV等。

例如,ADD指令可以将两个寄存器中的数据相加,并将结果保存在目标寄存器中。

1.3 逻辑运算指令逻辑运算指令用于进行逻辑运算,包括与、或、非、异或等操作,常见的指令有AND、OR、NOT、XOR等。

例如,AND指令可以对两个寄存器中的数据进行与运算,并将结果保存在目标寄存器中。

1.4 条件跳转指令条件跳转指令用于根据特定条件改变程序的执行流程,常见的指令有JZ、JNZ、JC、JNC等。

例如,JZ指令可以在累加器为零时跳转到指定的地址。

1.5 无条件跳转指令无条件跳转指令用于无条件地改变程序的执行流程,常见的指令有JMP、CALL、RET等。

例如,JMP指令可以跳转到指定的地址执行程序。

2. 常用指令的功能及应用示例2.1 MOV指令功能:将一个寄存器或内存的数据传送到另一个寄存器或内存。

示例:MOV A, B ; 将寄存器B的值传送给AMOV R1, #10 ; 将立即数10传送给寄存器R12.2 ADD指令功能:将两个寄存器或内存中的数据相加,并将结果保存在目标寄存器或内存中。

示例:ADD A, B ; 将A和B的值相加,并将结果保存在A中ADD R3, #5 ; 将寄存器R3的值加上立即数52.3 AND指令功能:对两个寄存器或内存中的数据进行逻辑与运算,并将结果保存在目标寄存器或内存中。

单片机指令大全

单片机指令大全

单片机指令大全单片机(Microcontroller)是一种集成了微处理器、存储器和输入/输出接口等功能的芯片,广泛应用于各种电子设备中。

在单片机的编程过程中,指令起到了至关重要的作用,指令的正确使用能够充分发挥单片机的性能和功能。

本文将详细介绍单片机常用的指令,并提供相应的格式和示例,以便读者更好地理解和运用。

一、数据传送指令数据传送指令用于从一个位置传送数据到另一个位置,常见的指令有MOV(Move)和LDR(Load Register)等。

1. MOV指令MOV指令用于将一个数据从一个位置复制到另一个位置。

格式如下:MOV 目的操作数,源操作数示例:MOV A, B ; 将寄存器B的值赋给寄存器AMOV R1, #10 ; 将立即数10赋给寄存器R12. LDR指令LDR指令用于将数据从存储器中加载到寄存器中。

格式如下:LDR 目的寄存器,来源地址示例:LDR R0, 0x1000 ; 将存储器地址0x1000处的数据加载到寄存器R0二、算术运算指令算术运算指令用于进行数值运算,如加法、减法、乘法和除法等。

常见的指令有ADD(Addition)和SUB(Subtraction)等。

1. ADD指令ADD指令用于进行加法运算,并将结果保存到指定的目标操作数中。

格式如下:ADD 目的操作数,源操作数示例:ADD A, B ; 将寄存器A和寄存器B的值相加,并将结果保存到寄存器A2. SUB指令SUB指令用于进行减法运算,并将结果保存到指定的目标操作数中。

格式如下:SUB 目的操作数,源操作数示例:SUB A, B ; 将寄存器A的值减去寄存器B的值,并将结果保存到寄存器A三、逻辑运算指令逻辑运算指令用于进行与、或、非、移位等逻辑操作。

常见的指令有AND(And)、OR(Or)和NOT(Not)等。

1. AND指令AND指令用于进行与运算,并将结果保存到指定的目标操作数中。

格式如下:AND 目的操作数,源操作数示例:AND A, B ; 将寄存器A和寄存器B的值进行与运算,并将结果保存到寄存器A2. OR指令OR指令用于进行或运算,并将结果保存到指定的目标操作数中。

完整word版单片机指令表最全

完整word版单片机指令表最全

单片机指令以A开头的指令有18条,分别为:7、ADDC A,direct指令名称:直接寻址带进位加法指令指令代码:35H指令功能:累加器内容、内部RAM低128单元或专用寄存器内1、ACALL addr11容与进位位加指令名称:绝对调用指令操作内容:A←(A)+(direct)+(C)指令代码:A10 A9 A8 10001 A7 A6 A5 A4 A3 A2 A1 A0字节数:2 指令功能:构造目的地址,进行子程序调用。

其方法是以指令提机器周期:1影响标志位:C,11供的11位地址(al0~a0),取代PC的低位,PC的高5位不变。

AC,OV操作内容:SP←(SP)+1PC←(PC)+2 8、ADDC A,@RiSP←(SP)+10 ~(SP)←(PC)7指令名称:间接寻址带进位加法指令指令代码:36H~37H0 ~~0←addrl0 (SP)←(PC)15~8 PC10指令功能:累加器内容, 内部RAM低128单元内容及进位位相加操作内容:A←(A)+((Ri))+(C)2 字节数:机器周期:2,i=0,1字节数:1 机器周期:位,使用说明:由于指令只给出子程序入口地址的低11因此调用1影响标志位:C,AC,OV范围是2KB。

9、ADDC A,、2ADD A,Rn#data指令名称:立即数带进位加法指令2FH指令代码:28H~指令代码:34H指令名称:寄存器加法指令指令功能:累加器内容、立即数及进位位相加指令功能:累加器内容与寄存器内容相加操作内容:A←(A)+(Rn)操作内容:,nA←(A)+data+(C) =0~7字节数:机器周期;12 机器周期:1字节数:1影响标志位:C影响标志位:,AC,C,AC,OVOV10、AJMP addr11 ADD A3、,direct指令名称:绝对转移指令指令代码:25H指令名称:直接寻址加法指令指令代码:RAM指令功能:累加器内容与内部单元或专用寄存器内容相加A10 A9 A8 1 0 0 0 1 A7 A6 A5 A4 A3 A2 A1 A0 指令功能:构造目的地址,实现程序转移。

完整word版,51单片机指令表

完整word版,51单片机指令表

此表主要是为了方便大家查阅每条指令的作用,写法以及字节数和周期数,建议大家保存为书签。

助记符指令说明字节数周期数(数据传递类指令)MOV A,Rn 寄存器传送到累加器 1 1MOV A,direct 直接地址传送到累加器 2 1MOV A,@Ri 累加器传送到外部RAM(8 地址) 1 1MOV A,#data 立即数传送到累加器 2 1MOV Rn,A 累加器传送到寄存器 1 1MOV Rn,direct 直接地址传送到寄存器 2 2MOV Rn,#data 累加器传送到直接地址 2 1MOV direct,Rn 寄存器传送到直接地址 2 1MOV direct,direct 直接地址传送到直接地址 3 2MOV direct,A 累加器传送到直接地址 2 1MOV direct,@Ri 间接RAM 传送到直接地址 2 2MOV direct,#data 立即数传送到直接地址 3 2MOV @Ri,A 直接地址传送到直接地址 1 2MOV @Ri,direct 直接地址传送到间接RAM 2 1MOV @Ri,#data 立即数传送到间接RAM 2 2MOV DPTR,#data16 16 位常数加载到数据指针 3 1 MOVC A,@A+DPTR 代码字节传送到累加器 1 2 MOVC A,@A+PC 代码字节传送到累加器 1 2 MOVX A,@Ri 外部RAM(8 地址)传送到累加器 1 2 MOVX A,@DPTR 外部RAM(16 地址)传送到累加器 1 2 MOVX @Ri,A 累加器传送到外部RAM(8 地址) 1 2 MOVX @DPTR,A 累加器传送到外部RAM(16 地址) 1 2 PUSH direct 直接地址压入堆栈 2 2POP direct 直接地址弹出堆栈 2 2XCH A,Rn 寄存器和累加器交换 1 1XCH A, direct 直接地址和累加器交换 2 1 XCH A, @Ri 间接RAM 和累加器交换 1 1 XCHD A, @Ri 间接RAM 和累加器交换低4 位字节 1 1(算术运算类指令)INC A 累加器加1 1 1 INC Rn 寄存器加1 1 1 INC direct 直接地址加1 2 1 INC @Ri 间接RAM 加1 1 1 INC DPTR 数据指针加1 1 2 DEC A 累加器减1 1 1 DEC Rn 寄存器减1 1 1 DEC direct 直接地址减1 2 2 DEC @Ri 间接RAM 减1 1 1 MUL AB 累加器和B 寄存器相乘 1 4 DIV AB 累加器除以B 寄存器 1 4 DA A 累加器十进制调整 1 1 ADD A,Rn 寄存器与累加器求和 1 1 ADD A,direct 直接地址与累加器求和 2 1 ADD A,@Ri 间接RAM 与累加器求和 1 1 ADD A,#data 立即数与累加器求和 2 1 ADDC A,Rn 寄存器与累加器求和(带进位) 1 1 ADDC A,direct 直接地址与累加器求和(带进位) 2 1 ADDC A,@Ri 间接RAM 与累加器求和(带进位) 1 1 ADDC A,#data 立即数与累加器求和(带进位) 2 1 SUBB A,Rn 累加器减去寄存器(带借位) 1 1 SUBB A,direct 累加器减去直接地址(带借位) 2 1 SUBB A,@Ri 累加器减去间接RAM(带借位) 1 1 SUBB A,#data 累加器减去立即数(带借位) 2 1(逻辑运算类指令)ANL A,Rn 寄存器“与”到累加器 1 1 ANL A,direct 直接地址“与”到累加器 2 1 ANL A,@Ri 间接RAM“与”到累加器 1 1 ANL A,#data 立即数“与”到累加器 2 1 ANL direct,A 累加器“与”到直接地址 2 1 ANL direct, #data 立即数“与”到直接地址 3 2 ORL A,Rn 寄存器“或”到累加器 1 2 ORL A,direct 直接地址“或”到累加器 2 1 ORL A,@Ri 间接RAM“或”到累加器 1 1 ORL A,#data 立即数“或”到累加器 2 1 ORL direct,A 累加器“或”到直接地址 2 1 ORL direct, #data 立即数“或”到直接地址 3 1 XRL A,Rn 寄存器“异或”到累加器 1 2 XRL A,direct 直接地址“异或”到累加器 2 1 XRL A,@Ri 间接RAM“异或”到累加器 1 1 XRL A,#data 立即数“异或”到累加器 2 1 XRL direct,A 累加器“异或”到直接地址 2 1 XRL direct, #data 立即数“异或”到直接地址 3 1 CLR A 累加器清零 1 2 CPL A 累加器求反 1 1 RL A 累加器循环左移 1 1 RLC A 带进位累加器循环左移 1 1 RR A 累加器循环右移 1 1 RRC A 带进位累加器循环右移 1 1 SWAP A 累加器高、低4 位交换 1 1(控制转移类指令)JMP @A+DPTR 相对DPTR 的无条件间接转移 1 2 JZ rel 累加器为0 则转移 2 2 JNZ rel 累加器为1 则转移 2 2CJNE A,direct,rel 比较直接地址和累加器,不相等转移 3 2 CJNE A,#data,rel 比较立即数和累加器,不相等转移 3 2 CJNE Rn,#data,rel 比较寄存器和立即数,不相等转移 2 2 CJNE @Ri,#data,rel 比较立即数和间接RAM,不相等转移 3 2 DJNZ Rn,rel 寄存器减1,不为0 则转移 3 2 DJNZ direct,rel 直接地址减1,不为0 则转移 3 2 NOP 空操作,用于短暂延时 1 1 ACALL add11 绝对调用子程序 2 2 LCALL add16 长调用子程序 3 2 RET 从子程序返回 1 2 RETI 从中断服务子程序返回 1 2 AJMP add11 无条件绝对转移 2 2 LJMP add16 无条件长转移 3 2 SJMP rel 无条件相对转移 2 2(布尔指令)CLR C 清进位位 1 1 CLR bit 清直接寻址位 2 1 SETB C 置位进位位 1 1 SETB bit 置位直接寻址位 2 1 CPL C 取反进位位 1 1 CPL bit 取反直接寻址位 2 1 ANL C,bit 直接寻址位“与”到进位位 2 2 ANL C,/bit 直接寻址位的反码“与”到进位位 2 2 ORL C,bit 直接寻址位“或”到进位位 2 2 ORL C,/bit 直接寻址位的反码“或”到进位位 2 2 MOV C,bit 直接寻址位传送到进位位 2 1 MOV bit, C 进位位位传送到直接寻址 2 2 JC rel 如果进位位为1 则转移 2 2 JNC rel 如果进位位为0 则转移 2 2JB bit,rel 如果直接寻址位为1 则转移 3 2 JNB bit,rel 如果直接寻址位为0 则转移 3 2 JBC bit,rel 直接寻址位为1 则转移并清除该位 2 2(伪指令)ORG 指明程序的开始位置DB 定义数据表DW 定义16 位的地址表EQU 给一个表达式或一个字符串起名DATA 给一个8 位的内部RAM 起名XDATA 给一个8 位的外部RAM 起名BIT 给一个可位寻址的位单元起名END 指出源程序到此为止(指令中的符号标识)Rn 工作寄存器R0-R7Ri 工作寄存器R0 和R1@Ri 间接寻址的8 位RAM 单元地址(00H-FFH)#data8 8 位常数#data16 16 位常数addr16 16 位目标地址,能转移或调用到64KROM 的任何地方addr11 11 位目标地址,在下条指令的2K 范围内转移或调用Rel 8 位偏移量,用于SJMP 和所有条件转移指令,范围-128~+127 Bit 片内RAM 中的可寻址位和SFR 的可寻址位Direct 直接地址,范围片内RAM 单元(00H-7FH)和80H-FFH$ 指本条指令的起始位置。

单片机指令(自己整理的)

单片机指令(自己整理的)

单片机指令单片机指令分为5类:数据传送类算术运算类逻辑运算及移位类控制转移类位操作类数据传送类指令:(29) 4、数据交换整字节交换:XCH A ,RnXCH A ,@Ri半字节交换:(A的低4位与RAM低4位交换)XCHD A ,@Ri累加器高低半字节交换:(A的高低半字节交换) SWAP A1、内部RAM数据传送8位立即数:MOV A, #dataMOV direct, #dataMOV @Ri, #dataMOV Rn, #data16位立即数:MOV DPTR, #data内部RAM之间:MOV direct2, direct1MOV direct2, @RiMOV direct2, RnMOV @Ri, direct1MOV Rn, direct通过累加器传送:MOV A, directMOV A, @RiMOV A, RnMOV direct, AMOV @Ri, A2、外部数据存储器读写(只能用A使用间址寻址)Ri作为间址寄存器:Movx A, @RiMovx @Ri, ADPTR作为间址寄存器:Movx A, @DPTRMovx @DPTR, A5、堆栈操作PUSH directPOP direct3、程序存储器读指令Movc A, @A+DPTRMovc A, @A+PC算术运算类(24)1、加法指令: 6、乘除:ADD A, #data 乘(低8位给A,高8位给B)ADD A, direct MUL ABADD A,@Ri 除(商给A,余数给B)ADD A, Rn DIV AB2、带进位加法: 7、十进制调整:(紧跟加减反指令后)ADDC A, #data DA AADDC A,@RiADDC A, Rn3、带借位减法:SUBB A, #dataSUBB A, directSUBB A, @RiSUBB A, Rn4、加1:INC AINC directINC @RiINC RnINC DPTR5、减1:DEC ADEC directDEC @RiDEC Rn逻辑运算及移位类指令(24)1、逻辑“与”运算:ANL direct, AANL direct, #dataANL A, #dataANL A, @RiANL A, Rn2、逻辑“或”运算:ORL direct, AORL direct, #dataORL A, #dataORL A, directORL A, @RiORL A, Rn3、逻辑“异或”运算:XRL direct, AXRL direct, #dataXRL A, #dataXRL A, directXRL A, @RiXRL A, Rn4、累加器清零和取反:CLR ACPL A5、移位指令:RL A (累加器循环左移) RR A (累加器循环右移) RLC A (通过CY循环左移) RRC A (通过CY循环右移)控制转移类指令(17)2、条件转移指令累加器判零转移指令: JZ rel (零转移)JNZ rel (非零转移)数值比较转移指令: CJNZ A, #data ,relCJNZ A, direct, relCJNZ Rn,#data, relCJNZ @Ri,#data, rel减1条件转移指令: DJNZ Rn, relDJNZ direct, rel1、无条件转移指令长转移指令: LJMP addr 16绝对转移: AJMP addr 11短转移: SJMP rel变址寻址转移: JMP @A+DPTR3、空操作指令NOP4、子程序调用与返回指令组绝对调用指令: ACALL addr 11长调用指令: LCALL addr 16返回指令: RETRETI位操作类指令(17)1、位传送指令组MOV C, bitMOV bit, C2、位置位复位指令组SETB CSETB bitCLR CCLR bit3、位逻辑运算指令组ANL C, bitANL C, /bitORL C, bitORL C, /bitCPL CCPL bit4、位控制转移指令以C状态为条件的转移指令 JC relJNC rel以位状态为条件的转移指令 JB bit, relJNB bit, relJBC bit, rel。

单片机指令大全

单片机指令大全

单片机指令大全- - 指令格式功能简述字节数周期一、数据传送类指令MOV A, Rn 寄存器送累加器 1 1 MOV Rn,A 累加器送寄存器 1 1 MOV A ,@Ri 内部RAM单元送累加器 1 1 MOV @Ri ,A 累加器送内部RAM单元 1 1 MOV A ,#data 立即数送累加器 2 1 MOV A ,direct 直接寻址单元送累加器 2 1 MOV direct ,A 累加器送直接寻址单元 2 1 MOV Rn,#data 立即数送寄存器 2 1 MOV direct ,#data 立即数送直接寻址单元 3 2 MOV @Ri ,#data 立即数送内部RAM单元 2 1 MOV direct ,Rn 寄存器送直接寻址单元 2 2 MOV Rn ,direct 直接寻址单元送寄存器 2 2 MOV direct ,@Ri 内部RAM单元送直接寻址单元 2 2 MOV @Ri ,direct 直接寻址单元送内部RAM单元 2 2 MOVdirect2,direct1 直接寻址单元送直接寻址单元 3 2 MOV DPTR ,#data16 16位立即数送数据指针 3 2MOVX A ,@Ri 外部RAM单元送累加器(8位地址) 1 2MOVX @Ri ,A 累加器送外部RAM单元(8位地址) 1 2MOVX A ,@DPTR 外部RAM单元送累加器(16位地址) 1 2MOVX @DPTR ,A 累加器送外部RAM单元(16位地址) 1 2MOVC A ,@A+DPTR 查表数据送累加器(DPTR为基址) 1 2MOVC A ,@A+PC 查表数据送累加器(PC为基址) 1 2XCH A ,Rn 累加器与寄存器交换 1 1 XCH A ,@Ri 累加器与内部RAM单元交换 1 1 XCHD A ,direct 累加器与直接寻址单元交换 2 1 XCHD A ,@Ri 累加器与内部RAM单元低4位交换 1 1SWAPA 累加器高4位与低4位交换 1 1 POP direct 栈顶弹出指令直接寻址单元 2 2 PUSH direct 直接寻址单元压入栈顶 2 2 二、算术运算类指令ADD A, Rn 累加器加寄存器 1 1 ADD A,@Ri 累加器加内部RAM单元 1 1 ADD A, direct 累加器加直接寻址单元 2 1 ADD A, #data 累加器加立即数 2 1 ADDC A, Rn 累加器加寄存器和进位标志 1 1 ADDC A,@Ri 累加器加内部RAM单元和进位标志 1 1ADDC A, #data 累加器加立即数和进位标志 2 1 ADDC A, direct 累加器加直接寻址单元和进位标志 2 1 INC A 累加器加1 1 1INC Rn 寄存器加1 1 1INC direct 直接寻址单元加1 2 1 INC @Ri 内部RAM单元加1 1 1 INC DPTR 数据指针加1 1 2 DA A 十进制调整 1 1 SUBB A, Rn 累加器减寄存器和进位标志 1 1 SUBBA,@Ri 累加器减内部RAM单元和进位标志 1 1 SUBB A, #data 累加器减立即数和进位标志 2 1 SUBB A, direct 累加器减直接寻址单元和进位标志 2 1 DEC A 累加器减1 1 1 DEC Rn 寄存器减1 1 1 DEC @Ri 内部RAM单元减1 1 1 DEC direct 直接寻址单元减1 2 1 MUL AB 累加器乘寄存器B 1 4 DIV AB 累加器除以寄存器B 1 4 三、逻辑运算类指令ANL A, Rn 累加器与寄存器 1 1 ANL A,@Ri 累加器与内部RAM单元 1 1 ANL A, #data 累加器与立即数 2 1 ANL A, direct 累加器与直接寻址单元 2 1 ANL direct, A 直接寻址单元与累加器 2 1 ANL direct, #data 直接寻址单元与立即数 3 1 ORL A, Rn 累加器或寄存器 1 1 ORL A,@Ri 累加器或内部RAM单元 1 1 ORL A,#data 累加器或立即数 2 1 ORL A,direct 累加器或直接寻址单元 2 1 ORL direct, A 直接寻址单元或累加器 2 1 ORLdirect, #data 直接寻址单元或立即数 3 1 XRL A, Rn 累加器异或寄存器 1 1 XRL A,@Ri 累加器异或内部RAM单元 1 1 XRL A,#data 累加器异或立即数 2 1 XRL A,direct 累加器异或直接寻址单元 2 1 XRL direct, A 直接寻址单元异或累加器 2 1 XRL direct, #data 直接寻址单元异或立即数 3 2 RL A 累加器左循环移位 1 1 RLC A 累加器连进位标志左循环移位 1 1 RR A 累加器右循环移位 1 1 RRC A 累加器连进位标志右循环移位 1 1 CPL A 累加器取反 1 1CLR A 累加器清零 1 1四、控制转移类指令类ACCALL addr11 2KB范围内绝对调用 2 2 AJMP addr11 2KB范围内绝对转移 2 2 LCALL addr16 2KB范围内长调用 3 2 LJMP addr16 2KB范围内长转移 3 2 SJMP rel 相对短转移 2 2 JMP @A+DPTR 相对长转移 1 2 RET子程序返回 1 2RET1 中断返回 1 2JZ rel 累加器为零转移 2 2JNZ rel 累加器非零转移 2 2 CJNE A ,#data ,rel 累加器与立即数不等转移 3 2 CJNE A ,direct ,rel 累加器与直接寻址单元不等转移 3 2 CJNE Rn,#data ,rel 寄存器与立即数不等转移 3 2 CJNE @Ri ,#data,rel RAM单元与立即数不等转移 3 2 DJNZ Rn ,rel 寄存器减1不为零转移 2 2 DJNZ direct ,rel 直接寻址单元减1不为零转移 3 2 NOP 空操作 1 1五、布尔操作类指令MOV C, bit 直接寻址位送C 2 1 MOV bit, C C送直接寻址位 2 1 CLR C C清零 1 1CLR bit 直接寻址位清零 2 1CPL C C取反 1 1CPL bit 直接寻址位取反 2 1 SETB C C置位 1 1 SETB bit 直接寻址位置位 2 1 ANLC, bit C逻辑与直接寻址位 2 2ANL C, /bit C逻辑与直接寻址位的反 2 2 ORL C, bit C逻辑或直接寻址位 2 2 ORL C, /bit C逻辑或直接寻址位的反 2 2 JC rel C为1转移 2 2 JNC rel C为零转移 2 2JB bit,rel 直接寻址位为1转移 3 2 JNB bit,rel 直接寻址为0转移 3 2 JBC bit,rel 直接寻址位为1转移并清该位 3 2单片机MCS-51系列指令快速记忆法随着微电子技术和超大规模集成电路技术的发展,单片微型计算机以其体积小、性价比高、功能强、可靠性高等独有的特点,在各个领域(如工业控制、家电产品、汽车电子、通信、智能仪器仪表)得到了广泛的应用。

单片机指令大全

单片机指令大全

单片机汇编指令大全2010-04-16 11:371 MOV A,Rn 寄存器内容送入累加器2 MOV A,direct 直接地址单元中的数据送入累加器3 MOV A,@Ri 间接RAM 中的数据送入累加器4 MOV A,#tata 立即数送入累加器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 间接RAM 中的数据送入直接地址单元12 MOV direct,#data 立即数送入直接地址单元13 MOV @Ri,A 累加器内容送间接RAM 单元14 MOV @Ri,direct 直接地址单元数据送入间接RAM 单元15 MOV @RI,#data 立即数送入间接RAM 单元16 MOV DRTR,#dat16 16 位立即数送入地址寄存器17 MOVC A,@A+DPTR 以DPTR为基地址变址寻址单元中的数据送入累加器18 MOVC A,@A+PC 以PC 为基地址变址寻址单元中的数据送入累加器19 MOVX A,@Ri 外部RAM(8 位地址)送入累加器20 MOVX A,@DPTR 外部RAM(16 位地址)送入累加器21 MOVX @Ri,A 累计器送外部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 间接RAM 与累加器交换28 XCHD A,@Ri 间接RAM 的低半字节与累加器交换算术操作类指令:1 ADD A,Rn 寄存器内容加到累加器2 ADD A,direct 直接地址单元的内容加到累加器3 ADD A,@Ri 间接ROM 的内容加到累加器4 ADD A,#data 立即数加到累加器5 ADDC A,Rn 寄存器内容带进位加到累加器6 ADDC A,direct 直接地址单元的内容带进位加到累加器7 ADDC A,@Ri 间接ROM 的内容带进位加到累加器8 ADDC A,#data 立即数带进位加到累加器9 SUBB A,Rn 累加器带借位减寄存器内容10 SUBB A,direct 累加器带借位减直接地址单元的内容11 SUBB A,@Ri 累加器带借位减间接RAM 中的内容12 SUBB A,#data 累加器带借位减立即数13 INC A 累加器加114 INC Rn 寄存器加115 INC direct 直接地址单元加116 INC @Ri 间接RAM 单元加117 DEC A 累加器减118 DEC Rn 寄存器减1 1 1219 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 CJNE 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 空操作ACC 与外部RAM 传送 返回主页微机常识单片机概论仿真与开发8051单片机引脚8051单片机指令汇编语言定时/记数器串行接口键盘与显示器原理8051单片外部RAM 数据传送指令 对外部RAM 单元只能使用寄存器间接寻址方式,与累加器A 之间进行数据传送,外部RAM 数据传送指令有4条。

MCS-51单片机指令表(打印版)

MCS-51单片机指令表(打印版)

数据存储器数据存储器也称为随机存取数据存储器。

数据存储器分为内部数据存储和外部数据存储。

MCS-51内部RAM有128或256个字节的用户数据存储(不同的型号有分别),片外最多可扩展64KB的RAM,构成两个地址空间,访问片内RAM用“MOV”指令,访问片外RAM用“MOVX”指令。

它们是用于存放执行的中间结果和过程数据的。

MCS-51的数据存储器均可读写,部分单元还可以位寻址。

MCS-51单片机的内部数据存储器在物理上和逻辑上都分为两个地址空间,即:数据存储器空间(低128单元);特殊功能寄存器空间(高128单元);这两个空间是相连的,从用户角度而言,低128单元才是真正的数据存储器。

下面我们就来详细的与大家讲解一下:低128单元:片内数据存储器为8位地址,所以最大可寻址的范围为256个单元地址,对片外数据存储器采用间接寻址方式,R0、R1和DPTR都可以做为间接寻址寄存器,R0、R1是8位的寄存器,即R0、R1的寻址范围最大为256个单元,而DPTR是16位地址指针,寻址范围就可达到64KB。

也就是说在寻址片外数据存储器时,寻址范围超过了256B,就不能用R0、R1做为间接寻址寄存器,而必须用DPTR寄存器做为间接寻址寄存器。

从上图中我们可以看到,8051单片机片内RAM共有256个单元(00H-FFH),这256个单元共分为两部分。

其一是地址从00H—7FH单元(共128个字节)为用户数据RAM。

从80H—FFH 地址单元(也是128个字节)为特殊寄存器(SFR)单元。

从下图中可清楚地看出它们的结构分布。

1、通用寄存器区(00H-1FH)在00H—1FH共32个单元中被均匀地分为四块,如下图,每块包含八个8位寄存器,均以R0—R7来命名,我们常称这些寄存器为通用寄存器。

这四块中的寄存器都称为R0—R7,那么在程序中怎么区分和使用它们呢?聪明的INTEL工程师们又安排了一个寄存器——程序状态字寄存器(PSW)来管理它们,CPU只要定义这个寄存的PSW的D3和D4位(RS0和RS1),即可选中这四组通用寄存器。

单片机指令表汇总

单片机指令表汇总

51单片机指令表汇总51单片机是一种广泛应用的微控制器,其指令集是进行编程的基础。

下面将51单片机的指令表进行汇总,以帮助初学者更好地理解其指令集。

一、数据传输指令1、MOV指令:将源操作数的内容传送到目标操作数。

2、XCH指令:将两个操作数的内容互换。

3、MOVC指令:从外部存储器将数据传送到目标操作数。

4、MOVX指令:将外部存储器中的数据传送到目标操作数。

5、PUSH指令:将数据压入堆栈。

6、POP指令:从堆栈中弹出数据。

二、算术运算指令1、ADD指令:将两个操作数相加,并将结果存放在目标操作数中。

2、SUB指令:从目标操作数中减去源操作数,并将结果存放在目标操作数中。

3、MUL指令:将两个操作数相乘,并将结果存放在目标操作数中。

4、DIV指令:将目标操作数除以源操作数,并将结果存放在目标操作数中。

5、ANL指令:对目标操作数和源操作数进行按位与运算,并将结果存放在目标操作数中。

6、ORL指令:对目标操作数和源操作数进行按位或运算,并将结果存放在目标操作数中。

7、XRL指令:对目标操作数和源操作数进行按位异或运算,并将结果存放在目标操作数中。

8、CPL指令:对目标操作数进行按位取反运算,并将结果存放在目标操作数中。

9、INC指令:将目标操作数加1。

10、DEC指令:将目标操作数减1。

11、ASR指令:将目标操作数右移n位,最高位用符号位补齐。

12、LSR指令:将目标操作数右移n位,最低位用0补齐。

13、ROL指令:将目标操作数循环左移n位,最高位移入最低位。

14、ROR指令:将目标操作数循环右移n位,最低位移入最高位。

单片机汇编指令表一、概述在单片机的世界里,汇编语言扮演着举足轻重的角色。

它是一种低级语言,能够直接与硬件进行交互,提供高效的代码执行效率。

下面,我们将详细列出一些常见的单片机汇编指令,以及它们的功能。

二、指令表1、MOV指令:用于将数据从一个寄存器移动到另一个寄存器。

例如,MOV R1, R2将把 R2的内容移动到 R1中。

单片机汇编语言指令表

单片机汇编语言指令表

附录5 MCS-51 指令表MCS-51指令中所用符号和含义Rn——当前工作寄存器组的8个工作寄存器(n=0~7)。

Ri——可用于间接寻址的寄存器,只能是当前寄存器组中的2个寄存器R0、R1(i=0,1)。

direct——内部RAM中的8位地址(包括内部RAM低128单元地址和专用寄存器单元地址)。

#data——8位常数。

#data16——16位常数。

addr16——16位目的地址,只限于在LCALL和LJMP指令中使用。

addr11——11位目的地址,只限于在ACALL和AJMP指令中使用。

rel——相对转移指令中的8位带符号偏移量。

DPTR——数据指针,16位寄存器,可用作16位地址寻址。

SP——堆栈指针,用来保护有用数据。

bit——内部RAM或专用寄存器中的直接寻址位。

A——累加器。

B——专用寄存器,用于乘法和除法指令或暂存器。

C——进位标志或进位位,或布尔处理机中的累加器。

@——间接寻址寄存器的前缀标志,如@Ri,@DPTR。

/——位操作数的前缀,表示对位操作数取反,如/bit。

(×)——以×的内容为地址的单元中的内容,X为表示指针的寄存器Ri(i=0、1)、DPTR、SP(Ri、DPTR、SP的内容均为地址)或直接地址单元。

如:为了区别地址单元与立即数如30H 单元与立即数30H,注释时,表述地址单元时用括号如(30H),立即数直接表示30H。

$——表示当前指令的地址。

<=>——表示数据交换。

←——箭头左边的内容被箭头右边的内容所代替。

附录6 AT89 系列单片机1.AT89 系列单片机简介AT89 系列单片机是ATMEL 公司的8 位Flash 单片机系列,这个系列单片机的最大特点是在片内含有Flash 存储器。

因此, 在应用中有着十分广泛的前途, 特别是在便携式省电及特殊信息保存的仪器和系统中显得更为有用。

AT89 系列单片机是以8051 核构成的, 它和8051 系列单片机是兼容的,故而对于熟悉8051 的用户来说, 用ATMEL公司的89 系列单片机进行取代8051 的系统设计是轻而易举的事2.8 9 系列单片机的优点1)内部含Flash 存储器。

单片机指令对照表精简

单片机指令对照表精简

SETB C SETB bit CPL C CPL bit ANL C,bit ANL C,/bit ORL C,bit ORL C,/bit MOV C,bit MOV bit,C
控制转移指令 (共 22 条) 共 对标志影响
机器码 助记符 功能 P (PC)+2→PC (SP)+1→SP (PC)L→SP (SP)+1→SP (PC)H→SP addr11→PC10~0 (PC)+2→PC (SP)+1→SP (PC)L→SP (SP)+1→SP (PC)H→SP addr16→PC ((SP))→PCH (SP)-1→SP ((SP))→PCL (SP)-1→SP ((SP))→PCH (SP)-1→SP ((SP))→PCL (SP)-1→SP 从中断返回 addr11 addr16 rel addr11 →PC10~0 addr16 →PC (PC)+(rel) →PC (A)+(DPTR)→PC (PC)+2→PC 若(A)=0,(PC)+(rel)→PC OV AC CY 字 节 数 周 期 数
1 1 1 1 2 1 1 1 1 1 2 1 1 1 1 1 1 1
数据传送指令 (共 28 条) 共
机器码 E8~EF E5 E6,E7 74 F8~FF A8--AF 78~7F F5 88~8F 85 86,87 75 F6,F7 A6,A7 76,77 90 93 83 E2,E3 E0 F2,F3 F0 C0 助记符 MOV A,Rn MOV A,driect MOV A,@Ri MOV A,#data MOV Rn,A MOV Rn,direct MOV Rn,#data MOV driect,A MOV driect,Rn MOV driect1,driect2 MOV driect,@Ri MOV driect,#data MOV @Ri,A MOV @Ri,driect MOV @Ri,#data MOV DPTR, #data16 MOVC A,@A+DPTR MOVC A,@A+PC MOVX A,@Ri MOVX A,@DPTR MOVX @Ri,A MOV @DPTR,A PUSH direct 功能 (Rn)→A (driect)→A ( (Ri) )→A data →A (A)→(Rn) (driect)→Rn data →Rn (A)→driect (Rn)→driect (driect2) →driect1 ( (Ri) )→driect data→driect (A)→(Ri) driect →(Ri) data →(Ri) data16 →DPTR ( (A)+(DPTR) )→A ( (A)+(PC) )→A ((Ri)+P2) →A ((DPTR)) →A (A)→(Ri)+(P2) (A)→(DPTR) (SP)+1→SP
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

单片机指令以A开头的指令有18条,分别为:1、ACALL addr11指令名称:绝对调用指令指令代码:A10 A9 A8 10001 A7 A6 A5 A4 A3 A2 A1 A0指令功能:构造目的地址,进行子程序调用。

其方法是以指令提供的11位地址(al0~a0),取代PC的低11位,PC的高5位不变。

操作内容:PC←(PC)+2SP←(SP)+1(SP)←(PC)7~0 SP←(SP)+1(SP)←(PC)15~8 PC10~0←addrl0~0字节数: 2 机器周期:2使用说明:由于指令只给出子程序入口地址的低11位,因此调用范围是2KB。

2、ADD A,Rn指令名称:寄存器加法指令指令代码:28H~2FH 指令功能:累加器内容与寄存器内容相加操作内容:A←(A)+(Rn),n=0~7字节数: 1 机器周期;1影响标志位:C,AC,OV3、ADD A,direct指令名称:直接寻址加法指令指令代码:25H 指令功能:累加器内容与内部RAM单元或专用寄存器内容相加操作内容:A←(A)+(direct)字节数: 2 机器周期:1影响标志位:C,AC,OV4、ADD A,@Ri ’指令名称:间接寻址加法指令指令代码:26H~27H 指令功能:累加器内容与内部RAM低128单元内容相加操作内容:A←(A)+((Ri)),i=0,1字节数: 1 机器周期:1影响标志位:C,AC,OV5、ADD A,#data指令名称:立即数加法指令指令代码:24H 指令功能:累加器内容与立即数相加操作内容:A←(A)+data字节数: 2 机器周期:1影响标志位:C,AC,OV6、ADDC A,Rn指令名称:寄存器带进位加法指令指令代码:38H~3FH 指令功能:累加器内容、寄存器内容和进位位相加操作内容:A←(A)+(Rn)+(C),n=0~7字节数: 1 机器周期:1 影响标志位:C,AC,OV7、ADDC A,direct指令名称:直接寻址带进位加法指令指令代码:35H 指令功能:累加器内容、内部RAM低128单元或专用寄存器内容与进位位加操作内容:A←(A)+(direct)+(C)字节数: 2 机器周期:1影响标志位:C,AC,OV8、ADDC A,@Ri指令名称:间接寻址带进位加法指令指令代码:36H~37H 指令功能:累加器内容, 内部RAM低128单元内容及进位位相加操作内容:A←(A)+((Ri))+(C),i=0,1字节数: 1 机器周期:1影响标志位:C,AC,OV9、ADDC A,#data指令名称:立即数带进位加法指令指令代码:34H 指令功能:累加器内容、立即数及进位位相加操作内容:A←(A)+data+(C)字节数: 2 机器周期:1影响标志位:C,AC,OV10、AJMP addr11指令名称:绝对转移指令指令代码:A10 A9 A8 1 0 0 0 1 A7 A6 A5 A4 A3 A2 A1 A0指令功能:构造目的地址,实现程序转移。

其方法是以指令提供的11位地址,取代PC的低11位,.而PC的高5位保持不变。

操作内容:PC←(PC)+2PCl0~0←addrll字节数: 2 机器周期:2使用说明:由于addrll的最小值是000H,最大值是7FFH,因此地址转移范围是2KB。

11、ANL A,Rn指令名称:寄存器逻辑与指令指令代码:58H~5FH 指令功能:累加器内容逻辑与寄存器内容操作内容:A←(A)∧(Rn),n=0~7字节数: 1 机器周期:112、ANL A,direct指令名称:直接寻址逻辑与指令指令代码:55H 指令功能:累加器内容逻辑与内部RAM低128单元或专用寄存器内容操作内容:A←(A)∧(diret)字节数: 2 机器周期:1精选13、ANL A,@Ri指令名称:间接寻址逻辑与指令指令代码:56H~57H 指令功能:累加器内容逻辑与内部RAM低128单元内容操作内容:A←(A)∧((Ri)) i=0,1字节数: 1 机器周期:114、ANL A,#data指令名称:立即数逻辑与指令指令代码:54H 指令功能:累加器内容逻辑与立即数操作内容:A←(A)∧data字节数: 2 机器周期:115、ANL direct,A指令名称:累加器逻辑与指令指令代码:52H 指令功能:内部RAM低128单元或专用寄存器内容逻辑与累加器内容操作内容:direct←(A)∧(direct)字节数: 2 机器周期:116、ANL direct,#data指令名称:逻辑与指令指令代码:53H 指令功能: 内部RAM低128单元或专用寄存器内容逻辑与立即数操作内容:direct←(direct)∧data字节数: 3 机器周期:217、ANL C,bit指令名称:位逻辑与指令指令代码:82H 指令功能:进位标志逻辑与直接寻址位操作内容:C←(C)∧(bit)字节数: 2 机器周期:218、ANL C,/bit指令名称:位逻辑与指令指令代码:B0H 指令功能:进位标志逻辑与直接寻址位的反操作内容:C←(C)∧(bit)字节数: 2 机器周期:2单片机指令以C开头的指令有10条,分别为:1、CJNE A,dircet,rel指令名称:数值比较转移指令指令代码:B5H 指令功能:累加器内容与内部RAM低128字节或专用寄存器内容比较,不等则转移。

操作内容:若(A)=(direct),则PC←(PC)+3,C←0若(A)>(direct),则PC←(PC)+3+rel,C←0若(A)<(direct),则PC←(PC)+3+rel,C←1字节数: 3 机器周期:2 2、CJNE A,#data,rel指令名称:数值比较转移指令指令代码:B4H 指令功能:累加器内容与立即数比较,不等则转移。

操作内容:若(A)=data,则PC←(PC)+3,C←0若(A)>data,则PC←(PC)+3+rel,C←0若(A)<data,则PC←(PC)+3+rel,C←1字节数: 3 机器周期:23、CJNE Rn,#data,rel指令名称:数值比较转移指令指令代码:B8H~BFH 指令功能:寄存器内容与立即数比较,不等则转移。

操作内容:若(Rn)=data,则PC←(PC)+3,C←0若(Rn)>data,则PC←(PC)+3+rel,C←0若(Rn)<data,则PC←(PC)+3+rel,C←1字节数: 3 机器周期:24、CJNE @Ri,#data,rel指令名称:数值比较转移指令指令代码:B6H~B7H 指令功能:内部RAM低128单元内容与立即数比较,不等则转移。

操作内容:若((Ri))=data,则PC←(PC)+3,C←0若((Ri))>data,则PC←(PC)+3+rel,C←0若((Ri))<data,则PC←(PC)+3+rel,C←1字节数: 3 机器周期:25、CLR A指令名称:累加器清0指令指令代码:E4H 指令功能:累加器清0 操作内容:A←0字节数: 1 机器周期:16、CLR C指令名称:进位标志清0指令指令代码:C3H 指令功能:进位位清0操作内容:C←0字节数: 1 机器周期:17、CLR bit指令名称:直接寻址位清0指令指令代码:C2H 指令功能:直接寻址位清0操作内容:bit←0字节数: 2 机器周期:18、CPL A指令名称:累加器取反指令指令代码:F4H 指令功能:累加器取反操作内容:A←(A)字节数: 1 机器周期:1精选9、CPL C指令名称:进位标志取反指令指令代码:B3H 指令功能:进位标志位状态取反操作内容:C←(c取反)字节数: 1 机器周期:110、CPL bit指令名称:直接寻址位取反指令指令代码:B2H 指令功能:直接寻址位取反操作内容:bit←(bit取反)字节数: 2 机器周期:1单片机指令以D开头的指令有8条,分别为:1、DA A指令名称:十进制调整指令指令代码:D4H 指令功能:对BCD码加法运算的结果进行有条件的修正操作内容:若(A)3~0>9∨(AC)=1,则A3~0←(A)3~0+6若(A)7~4>9∨(C)=1,则A7~4←(A)7~4+6若(A)7~4=9∧(A)3~0>9,则A7~4←(A)7~4+6 字节数: 1 机器周期:1使用说明:DA指令不影响溢出标志2、DEC A指令名称:累加器减1指令指令代码:14H 指令功能:累加器内容减1操作内容:A←(A)-1字节数: 1 机器周期:13、DEC Rn指令名称:寄存器减1指令指令代码:18H~1FH 指令功能:寄存器内容减1操作内容:Rn←(Rn)-1,n=0~7字节数: 1 机器周期:14、DEC direct指令名称:直接寻址减1指令指令代码:15H 指令功能:内部RAM低128单元及专用寄存器内容减1操作内容:direct←(direct)-1字节数: 2 机器周期:15、DEC @Ri指令名称:间接寻址减1指令指令代码:16H~17H 指令功能:内部RAM低128单元内容减1操作内容:(Ri)←((Ri))-1,i=0,1字节数: 1 机器周期:16、DIV AB 指令名称:无符号数除法指令;指令代码:84H 指令功能:A的内容被B的内容除。

指令执行后,商存于A中,余数存于B中。

操作内容:A←(A)/(B)的商B←(A)/(B)的余数字节数: 1 机器周期:4影响标志位:C被清0;若B=00H,除法无法进行,并使OV=1;否则OV=0。

7、DJNZ Rn,rel指令名称:寄存器减1条件转移指令指令代码:D8H~DFH 指令功能:寄存器内容减1。

不为0转移;为0顺序执行。

操作内容:Rn←(Rn)-l,n=0~7若(Rn)≠0,则PC←(PC)+2+rel若(Rn)=0,则PC←(PC)+2字节数: 2 机器周期:28、DJNZ direct,rel指令名称:直接寻址单元减1条件转移指令指令代码:D5H 指令功能:内部RAM低128单元内容减1。

不为0转移;为0顺序执行。

操作内容:direct←(direct)-1若(direct)≠0,则PC←(PC)+3+rel若(direct)=0,则PC←(PC)+3字节数: 3 机器周期:2单片机指令以I开头的指令有5条,分别为:1、INC A指令名称:累加器加1指令指令代码:04H指令功能:累加器内容加1操作内容:A←(A)+1字节数: 1 机器周期:12、INC Rn指令名称:寄存器加1指令指令代码:08H~0FH 指令功能:寄存器内容加1操作内容:Rn←(Rn)+1,n=0~7字节数: 1 机器周期:13、INC direct指令名称:直接寻址单元加1指令指令代码:05H指令功能:内部BAM低128单元或专用寄存器内容加1操作内容:direct←(direct)+1字节数: 2 机器周期:14、INC @Ri指令名称:间接寻址单元加1指令指令代码:06H~07H 指令功能:内部RAM低128单元内容加1操作内容:(Ri)←((Ri))+1;i=0,l精选字节数: 1 机器周期:15、INC DPTR指令名称:16位数据指针加1指令指令代码:A3H 指令功能:数据指针寄存器DPTR内容加1操作内容:DPTR←(DPTR)+1字节数: 1 机器周期:2单片机指令以J开头的指令有8条,分别为:1、JB bit,rel指令名称:位条件转移指令。

相关文档
最新文档