单片机汇编语言 汇编语言是高级语言吗
大家好,今天来为大家解答单片机汇编语言这个问题的一些问题点,包括汇编语言是高级语言吗也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起来看看吧!如果解决了您的问题,还望您关注下本站哦,谢谢~
51单片机的指令是汇编语言吗
我来回答
所有的处理器内部处理的都是二进制信号,也只能识别二进制信号,所以不管用什么样的语言写的程序,终将经转换成二进制的形式下载到芯片中去才能运行。但是用二进制指令不便于编写程序,也难于分析程序。而且学习起来不方便,所以就更加难于推广。
所以人们就想到了一个方法,用一些特定的符号(见名知意)来代替二进制指令。这就是我们所说的汇编语言。比如上面所说的MOV A,#3EH。其实,每条汇编指令,都对应唯一的一个二进制编码。
但不同体系的CPU。都有不同的汇编语言。虽是解决了不便于编写程序,难于分析程序的问题,但还是制约了推广,所以就出现以高级语言。(如C,C++,JAVA),但用高级语言编写出的程序,还是会经过编译器转换成来汇编程序,再转换成二进制的指令,下载到芯片中去。
这样就方便学习和推广。比如说,如果你懂C语言的话,就可以写很多体系CPU的应用程序。但如何转换为二进制指令的话,就由编译器来完成了。
所以强列建议你去学习C语言,这是一种经典的语言。对于应用开发很有用。
汇编语言和单片机的区别
软件和硬件。
单片机是硬件,汇编是语言,是软件。
单片机从诞生到现在,经过了将近70年的发展。众所周知,单片机是可以通过编写程序实现产品的功能,这么多年来,单片机的规格并没有多大变化,而单片机编程一般使用的都是汇编语言和c语言。
汇编语言是一种用文字助记符来表示机械指令的符号语言,是最接近机械码的一种语言。
汇编语言在51单片机中的所有指令有那些
单片机指令功能一览表
助记符代码说明
MOV A,Rn E8~EF寄存器A
MOV A,direct E5 dircet直接字节送A
MOV A,@Ri ER~E7间接RAM送A
MOV A,#data 74 data立即数送A
MOV Rn,A F8~FF A送寄存器
MOV Rn,dircet A8~AF dircet直接字节送寄存器
MOV Rn,#data 78~7F data立即数送寄存器
MOV dircet,A F5 dircet A送直接字节
MOV dircet,Rn 88~8F dircet寄存器送直接字节
MOV dircet1,dircet2 85 dircet1 dircet2直接字节送直接字节
MOV dircet,@Ro 86~87间接RAM送直接字节
MOV dircet,#data 75 dircet data立即数送直接字节
MOV@Ri,A F6~F7 A送间接RAM
MOV@Ri,#data 76~77 data直接字节送间接RAM
MOV@Ri,#data 76~77 data立即数送间接RAM
MOV DPTR,#data16 90 data 15~8 16位常数送数据指针
data7~0
MOVC A,@A+DPTR 93由((A)+(DPTR))寻址的程序存贮
器字节选A
MOVC A,@A+PC 83由((A)+(PC));寻址的程序存贮器字节送A
MOVX A,@Ri E2~E3送外部数据(8位地址)送A
MOVX A,@DPTR E0送外部数据(16位地址)送A
MOVX@Ri,A F2~F3 A送外部数据(8位地址)
MOVX@DPTR,A F0 A送外部数据(16位地址)
PUSH dircet C0 dircet直接字节进栈,SP加1
POP dircet D0 dircet直接字节退栈,SP减1
XCH A,Rn C8~CF交换A和寄存器
XCH A,dircet C5 dircet交换A和直接字节
XCH A,@Ri C6~C7交换A和间接RAM
XCH A,@Ri D6~D7交换A和间接RAM的低位
SWAP A C4
算术操作(A的二个半字节交换)
ADD A,Rn 28~2F寄存器加到A
ADD A,dircet 25 dircet直接字节加到A
ADD A,@Ri 26~27间接RAM加到A
ADD A,#data 24data立即数加到A
ADD A,Rn 38~3F寄存器和进位位加到A
ADD A,dircet 35dircet直接字节和进位位加到A
ADD A,@Ri 36~37间接字节和进位位加到A
ADD A,data 34 data立即数和进位位加到A
ADD A,Rn 98~9F A减去寄存器和进位位
ADD A,dircet 95 dircet A减去直接字节和进位位
ADD A,@Ri 36~37间接RAM和进位位加到A
ADD A,data 34 data立即数和进位位加到A
SUBB A,Rn 98~9F A减去寄存器和进位位
SUBB A,dircet 95 dircet A减去直接字节和进位位
SUBB A,@Ri 96~97 A减去间接RAM和进位位
SUBB A,#data 94 data A减去立即数和进位位
INC A 04 A加1
INC Rn 08~0F寄存器加1
INC dircet 05 dircet直接字节加1
INC@Ri 06~07间接RAM加1
DEC A 14 A减1
DEC Rn 18~1F寄存器减1
DEC dircet 15 dircet直接字节减1
DEC@Ri 16~17间接RAM减1
INC DPTR A3数据指针加1
MUL AB A4 A乘以B
DIV AB 84 A除以B
DA A D4 A的十进制加法调整
逻辑操作
ANL A,Rn 58~5F寄存器“与”到A
ANL A,dircet 55 dircet直接字节“与”到A
ANL A,@Ri 56~57间接RAm“与”到A
ANL A,#data 54 data立即数“与”到A
ANL dircet A 52 dircet A“与”到直接字节
ANL dircet,#data 53 dircet data立即数“与”到直接字节
ORL A,Rn 48~4F寄存器“或”到A
ORL A,dircet 45 dircet直接字节“或”到A
ORL A,@Ri 46~47间接RAM“或”到A
ORL A,#data 44 data立即数“或”到A
ORL dircet,A 42 dircet A“或”到直接字节
ORL dircet,#data 43 dircet data立即数“或”到直接字节
XRL A,Rn 68~6F寄存器“异或”到A
XRL A,dircet 65 dircet直接字节“异或”到A
XRL A,@Ri 66~67间接RAM“异或”到A
XRL A,#data 64 data立即数“异或”到A
XRL dircet A 62 dircet A“异或”到直接字节
XRL dircet,#data 63 dircet data立即数“异或”到直接字节
CLR A E4清零
CPL A F4 A取反
RL A 23 A左环移
RLC A 33 A通过进位左环移
RR A 03 A右环移
RRC A 13 A通过进位右环移
控制程序转移
ACALL addr 11*1 addr(a7~a0)绝对子程序调用
LCALL addr 16 12 addr(15~8)长子程序调用
addr(7~0)
RET 22子程序调用返回
RETI addr 11 32中断调用返回
AJMP addr 11△1 addr(a7~a6)绝对转移
LJMP addr 16 02addr(15~8)长转移
addr(7~0)
SJMP rel 80 rel短转移,相对转移
JMP@A+DPTR 73相对于DPTR间接转移
JZ rel 60 rel A为零转移
JNZ rel 70 rel A为零转移
CJNE A,dircet,rel B5 dircet rel直接字节与A比较,不等则转移
CJNE A,#data,rel B4 data rel立即数与A比较,不等则转移
CJNE A,Rn,#data,rel B8~BF data rel立即数与寄存器比较,不等则转移
CJNE@Ri,#data,rel B6~B7 data rel立即数与间接RAM比较,不等则转移
DJNZ Rn,rel D8~DF rel寄存器减1,不为零则转移
DJNZ dircet,rel B5 dircet rel直接字节减1,不为零则转移
NOP 00空操作
*=a10a9a8l
△=a10a9a80
布尔变量操作
CLR C C3清零进位
CLR bit C2清零直接位
SETB C D3置位进位
SETB bit D2置位直接位
CPL C B3进位取反
CPL bit B2直接位取反
ANL C,bit 82 dit直接数“与”到进位
ANL C,/bit B0直接位的反“与”到进位
ORL C,bit 72 bit直接位“或”到进位
ORL C,/bit A0 bit直接位的反“或”到进位
MOV C,bit A2 bit直接位送进位
MOV bit,C 92 bit进位送直接位
JC rel 40 rel进位位为1转移
JNC rel 50 rel进位位为0转移
JB bit,rel 20 bit rel直接位为1相对转移
JNB bit,rel 30 bit rel直接位为0相对转移
JBC bit,rel 10 bit rel直接位为1相对转移,然后清零该位
[1].循环移位指令(4条)
RL A;累加器A中的内容左移一位
RR A;累加器A中的内容右移一位
RLC A;累加器A中的内容连同进位位CY左移一位
RRC A;累加器A中的内容连同进位位CY右移一位
[2].累加器半字节交换指令(1条)
SWAP A;累加器中的内容高低半字节互换
[3].求反指令(1条)
CPL A;累加器中的内容按位取反
[4].清零指令(1条)
CLR A; 0→(A),累加器中的内容清0
[5].逻辑与操作指令(6条)
ANL A,data;累加器A中的内容和直接地址单元中的内容执行与逻辑操作。结果存在寄存器A中。
ANL data,#data;直接地址单元中的内容和立即数执行与逻辑操作。结果存在直接地址单元中。
ANL A,#data;累加器A的内容和立即数执行与逻辑操作。结果存在累加器A中。
ANL A,Rn;累加器A的内容和寄存器Rn中的内容执行与逻辑操作。结果存在累加器A中。
ANL data,A;直接地址单元中的内容和累加器A的内容执行与逻辑操作。结果存在直接地址单元中。
ANL A,@Ri;累加器A的内容和工作寄存器Ri指向的地址单元中的内容执行与逻辑操作。结果存在累加器A中。
[6].逻辑或操作指令(6条)
这组指令的作用是将两个单元中的内容执行逻辑或操作。如果直接地址是I/O地址,则为“读—修改—写”操作。
ORL A,data;累加器A中的内容和直接地址单元中的内容执行逻辑或操作。结果存在寄存器A中。
ORL data,#data;直接地址单元中的内容和立即数执行逻辑或操作。结果存在直接地址单元中。
ORL A,#data;累加器A的内容和立即数执行逻辑或操作。结果存在累加器A中。
ORL A,Rn;累加器A的内容和寄存器Rn中的内容执行逻辑或操作。结果存在累加器A中。
ORL data,A;直接地址单元中的内容和累加器A的内容执行逻辑或操作。结果存在直接地址单元中。
ORL A,@Ri;累加器A的内容和工作寄存器Ri指向的地址单元中的内容执行逻辑或操作。结果存在累加器A中。
[7].逻辑异或操作指令(6条)
XRL A,data;累加器A中的内容和直接地址单元中的内容执行逻辑异或操作。结果存在寄存器A中。
XRL data,#data;直接地址单元中的内容和立即数执行逻辑异或操作。结果存在直接地址单元中。
XRL A,#data;累加器A的内容和立即数执行逻辑异或操作。结果存在累加器A中。
XRL A,Rn;累加器A的内容和寄存器Rn中的内容执行逻辑异或操作。结果存在累加器A中。
XRL data,A;直接地址单元中的内容和累加器A的内容执行逻辑异或操作。结果存在直接地址单元中。
XRL A,@Ri;累加器A的内容和工作寄存器Ri指向的地址单元中的内容执行逻辑异或操作。结果存在累加器A中
控制转移类指令分析
[1].无条件转移指令(4条)
LJMP addr16;addr16→(PC),给程序计数器赋予新值(16位地址)
AJMP addr11;(PC)+2→(PC),addr11→(PC10-0)程序计数器赋予新值(11位地址),(PC15-11)不改变
SJMP rel;(PC)+ 2+ rel→(PC)当前程序计数器先加上2再加上偏移量给程序计数器赋予新值
JMP@A+DPTR;(A)+(DPTR)→(PC),累加器所指向地址单元的值加上数据指针的值给程序计数器赋予新值
[2].条件转移指令(8条)
JZ rel; A=0,(PC)+ 2+ rel→(PC),累加器中的内容为0,则转移到偏移量所指向的地址,否则程序往下执行
JNZ rel; A≠0,(PC)+ 2+ rel→(PC),累加器中的内容不为0,则转移到偏移量所指向的地址,否则程序往下执行
CJNE A, data, rel; A≠(data),(PC)+ 3+ rel→(PC),累加器中的内容不等于直接地址单元的内容,则转移到偏移量所指向的地址,否则程序往下执行
CJNE A,#data, rel; A≠#data,(PC)+ 3+ rel→(PC),累加器中的内容不等于立即数,则转移到偏移量所指向的地址,否则程序往下执行
CJNE Rn,#data, rel; A≠#data,(PC)+ 3+ rel→(PC),工作寄存器Rn中的内容不等于立即数,则转移到偏移量所指向的地址,否则程序往下执行
CJNE@Ri,#data, rel; A≠#data,(PC)+ 3+ rel→(PC),工作寄存器Ri指向地址单元中的内容不等于立即数,则转移到偏移量所指向的地址,否则程序往下执行
布尔变量操作指令分析
[1].位传送指令(2条)
MOV C,bit;bit→CY,某位数据送CY
MOV bit,C;CY→bit,CY数据送某位
[2].位置位复位指令(4条)
CLR C; 0→CY,清CY
CLR bit; 0→bit,清某一位
SETB C; 1→CY,置位CY
SETB bit; 1→bit,置位某一位
[3].位运算指令(6条)
ANL C,bit;(CY)∧(bit)→CY
ANL C,/bit;(CY)∧()→CY
ORL C,bit;(CY)∨(bit)→CY
ORL C,/bit;(CY)∧()→CY
CPL C;()→CY
CPL bit;()→bir
[4].位控制转移指令(5)
JC rel;(CY)=1转移,(PC)+2+rel→PC,否则程序往下执行,(PC)+2→PC。
JNC rel;(CY)=0转移,(PC)+2+rel→PC,否则程序往下执行,(PC)+2→PC。
JB bit, rel;位状态为1转移。
JNB bit, rel;位状态为0转移。
JBC bit, rel;位状态为1转移,并使该位清“0”。
关于本次单片机汇编语言和汇编语言是高级语言吗的问题分享到这里就结束了,如果解决了您的问题,我们非常高兴。