谈谈51单片机的指令字节数

合集下载

谈谈51单片机的指令字节数

谈谈51单片机的指令字节数

谈谈51单片机的指令字节数现在的单片机程序大多都用C语言来编写了,汇编看起来有点OUT了。

可是有时候汇编却很有用,因为它执行的效率高,而且每条指令占用的字节数和时钟周期都是确定的,这对于查表编程及对时钟要求严格的地方来说,是非常有用的。

在嵌入式操作系统的移植中,有一部分代码是得用汇编来写的,不过这跟今天要谈的内容无关。

现有来谈谈MCS-51单片机的指令的字节数。

汇编语言的语句的格式为:标号段:操作码段第一操作数,第二操作数;注释段(如START: MOV A,#00H ;把0赋给A)其中操作码段是必段的,其他的段是根据不同的指令而不同,操作数段可以只有一个操作数,也可以有两个操作数,有时还会有三个操作数的情况。

在51单片机中,有单字节指令、双字节指令和三字节指令。

只要理解了指令占用的这些字节都是用来存放哪些量的,那自然就会判断不同的指令是多少字节指令了。

1、操作码段占用一个字节。

2、8位立即数占用一个字节,16位立即数占用两个字节。

3、8位操作数地址占用一个字节,16位操作数地址占用两个字节。

4、CPU内部的各种寄存器不占用指令字节,如A, B, R0, R1, DPTR等。

现在就可以判断51的指令占用的字节数了:MOV A, R0 ;这是单字节指令,其中MOV占用一个字节,A和R0是CPU内部寄存器,不占用指令字节。

MOV A, #07H ;这是双字节指令,其中MOV占用一个字节,8位立即数#07H占用一个字节。

MOV DPTR, #0106H ;这是三字节指令,MOV占用一个字节,16位立即数#0106H 占用两个字节。

MOV 07H, #07H ;这是三字节指令,MOV占用一个字节,8位地址07H占用一个字节,8位立即数#07H占用一个字节。

关于BCD 码减数求补的问题2009-11-23 2:40有这样一个问题:汇编程序如下:ORG 0100HMOV R1, #50HMOV R0, #60HCLR CCALL BSUBMOV 40H, A...BSUB: MOV A, #9AHSUBB A, @R0ADD A, @R1DA AINC R0INC R1CPL CRET问:其中9AH 的作用是什么,能不能换成别的数!问题补充:BCD 码减法程序。

MCS51单片机指令系统

MCS51单片机指令系统

第一条指令为远查表指令,可以在64K的程序存储器空间寻 址。基地址寄存器为DPTR,其意思为,DPTR里面存放的是 程序存储器中数据表格的首地址,A为数据地址的偏移量。
这条指令执行以后,以 (A)+(DPTR)的数值为地址数 据就送进A里面来了,也就是从表格首地址开始以后的第(A) 个数据被送进A了。(举例子说明)
编写好的程序都放在程序存储器中,由于一个存储地址所 指示的存储单元只能存放一字节的数据。所以,在存放指令时, 必须将指令拆分成一个一个字节进行连续存放。
比如: 实现“累加器加10H”这条指令,其机器语言为 0111010000010000, 占用了两个字节,就必须拆成两个字节 进行连续存储。
但是,用二进制来表示比较麻烦,因此,也常用十六进制来 表示如:74H 10H来表示以上这条机器语言。可见,用十六进 制表示指令比较简单,但是,指令系统有上百条指令,不易记 住。所以,一般采用容易记住的一些缩写符号来表示机器语言,
2. 在指令中直接给出操作数的地址, 这种寻址方式就属
于直接寻址方式。在这种方式中, 指令的操作数部分直接 是操作数的地址。
比如:MOV A,30H;将30H里面的数送到A里面 MOV 21H,30H;将30H里面的数存放到21H里面 在MCS -51 单片机指令系统中, 直接寻址方式中可
以访问 3 种存储器空间: (1) 内部数据存储器的低 128 个字节单元(00H~
7. 位寻址 指按照位进行的寻址操作,(前面讲的都是按字节进
行的寻址操作)。该种寻址方式中, 操作数是内部RAM单元 中20H到2FH的128个位地址以及SFR中的11个可进行 位寻址的寄存器中的位地址寻址。
比如:MOV C,20H;就是将RAM中位寻址区中20H位地 址中的内容送给C。区别与MOV A,20H;这个是将内部 RAM中20H单元的内容送给A。

51单片机汇编语言入门教程

51单片机汇编语言入门教程

51单片机汇编语言入门教程什么是51单片机
51单片机指的是英特尔公司推出的一种单片机芯片种类,其名字为“AT89S52”。

后来,这种芯片因其使用广泛,被人们简称为“51单片机”。

为什么要研究汇编语言
研究汇编语言能够让我们更好地理解机器是如何执行指令的,
从而更好地优化程序,提高程序运行效率。

汇编语言基础知识
数据类型
- 字节:一个字节是8位二进制数,可以表示0~255之间的数。

- 字:一个字是16位二进制数,可以表示0~之间的数。

- 双字:一个双字是32位二进制数,可以表示0~之间的数。

指令集
51单片机有大约100条汇编指令,这些指令可以完成各种操作,如运算、数据传输、中断处理等。

寄存器
51单片机有4个8位的通用寄存器(寄存器0~3)和2个16
位的通用寄存器(DPTR和PC)。

程序结构
51单片机只有一种程序结构——线性结构。

程序从0地址开始执行,一条一条地执行,直到程序结束。

编写第一个汇编程序
以下是一个简单的汇编程序示例:
ORG 0H ;设置程序起始地址为0H
MOV P1, #55H ;将55H赋值给P1口
END ;程序结束指令
这个程序的作用是将55H赋值给P1口。

总结
通过学习本教程,我们了解了基本的汇编语言知识,包括数据
类型、指令集、寄存器、程序结构以及编写程序的基本步骤。

希望
这份教程可以帮助初学者顺利掌握51单片机汇编语言编程的基础。

8051单片机指令表

8051单片机指令表
XCH A,Rn 寄存器和累加器交换 1 1
XCH A, direct 直接地址和累加器交换 2 1
XCH A, @Ri 间接RAM 和累加器交换 1 1
XCHD A, @Ri 间接RAM 和累加器交换低4 位字节 1 1
(算术运算类指令)
INC A 累加器加1 1 1
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
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 direct,A 累加器传送到直接地址 2 1
MOV direct,@Ri 间接RAM 传送到直接地址 2 2
MOV direct,#data 立即数传送到直接地址 3 2
MOV @Ri,A 直接地址传送到直接地址 1 2
MOV @Ri,direct 直接地址传送到间接RAM 2 1
(逻辑运算类指令)
ANL A,Rn 寄存器“与”到累加器 1 1
ANL A,direct 直接地址“与”到累加器 2 1
ANL A,@Ri 间接RAM“与”到累加器 1 1
ANL A,#data 立即数“与”到累加器 2 1

51单片机汇编指令详解

51单片机汇编指令详解

51单片机汇编指令详解1、XCH A,Rn指令名称:寄存器寻址字节交换指令指令代码:C8H~CFH指令功能:寄存器寻址字节操作内容:(A)交换(Rn);n=0~7字节数: 1机器周期:12、XCH A,direct指令名称:直接寻址字节交换指令指令代码:C5H指令功能:累加器内容与内部RAM低128单元或专用寄存器内容交换操作内容:(A)交换(direct)字节数: 2机器周期:13、XCH A,@Ri指令名称:间接寻址字节交换指令指令代码:C6H~C7H指令功能:累加器内容与内部RAM低128单元内容交换操作内容:(A)交换((Ri)); i=0,1字节数: 1机器周期:14、XCHD A,@Ri指令名称:半字节交换指令指令代码:D6H~D7H指令功能:累加器内容低4位与内部RAM低128单元低4位交换操作内容:(A)3~0交换((Ri))3~0;i=0,1字节数: 1机器周期:15、XRL A,Rn指令名称;逻辑异或操作指令指令代码:68H~6FH指令功能:累加器内容与寄存器内容进行逻辑异或操作操作内容:A<-(A)异或(Rn); n=0~7字节数: 1机器周期:16、XRL A,direct指令名称:逻辑异或操作指令指令代码:65H指令功能:累加器内容与内部RAM低128单元或专用寄存器内容进行逻辑异或操作操作内容:A<-(A)异或(direct)字节数: 2机器周期:17、XRL A,@Ri指令名称:逻辑异或指令指令代码:66H~67H指令功能:累加器与内部RAM低128单元内容进行逻辑异或操作操作内容:A<-(A)异或((Ri)); i=0,1字节数: 1机器周期:18、XRL A,#data指令名称:逻辑异或指令指令代码:64H指令功能:累加器内容与立即数进行逻辑异或操作操作内容:A1?/FONT>(A)异或data字节数: 2机器周期:19、XRL direct,A指令名称:逻辑异或操作指令指令代码:62H指令功能:累加器内容与内部RAM低128单元或专用寄存器内容进行逻辑异或操作操作内容:direct一(direct)异或(A)字节数: 2机器周期:110、XRL direct,#data指令名称:逻辑异或操作指令指令代码:63H指令功能:内部RAM低128单元或专用寄存器内容与立即数进行逻辑异或操作操作内容:direct<-(direct)异或data字节数: 3机器周期:2以R开头的指令有6条,分别为:RETRETIRL ARLC ARR ARRC A1、RET指令名称:子程序返回指令指令代码:22H指令功能:子程序返回操作内容:PC15~8<-((SP))SP<-(SP)-1PC7~0<-((SP))SP<-(SP)-1字节数: 1机器周期:22、RETI指令名称:中断返回指令指令代码:32H指令功能:中断服务程序返回操作内容’:PC15?/FONT>8<-((SP))SP<-(SP)-lPC7~0<-((SP))SP<-(SP)-1字节数: 1机器周期:23、RL A指令名称:循环左移指令指令代码:23H指令功能:累加器内容循环左移一位操作内容:An+1<-(An); n=0~6A0<-(A7)字节数: 1机器周期:14、RLC A指令名称:带进位循环左移指令指令代码:33H指令功能:累加器内容连同进位标志位循环左移一位操作内容:An-1<-(An); n=0~6A0<-(C)C<-(A7)字节数: 1机器周期:15、RR A指令名称:循环右移指令指令代码:03H指令功能:累加器内容循环右移一位操作内容:An<-(An+1);n=0~6A7<-(A0)字节数: 1机器周期:16、RRC A指令名称:带进位循环右移指令指令代码:13H指令功能:累加器内容连同进位标志位循环右移一位操作内容:An<-(An+1);n=0~6A7<-(C)C<-(A0)字节数: 1机器周期:11、SETB c指令名称:进位标志置位指令指令代码:D.H指令功能:进位标志位置位操作内容:C<-1字节数: 1机器周期:12、SETB bit指令名称:直接寻址位置位指令指令代码:D2H指令功能:内部RAM可寻址位或专用寄存器指定位置位操作内容:bit<-1字节数: 2机器周期:13、SJMP rel指令名称:短转移指令指令代码:80H指令功能:按指令提供的偏移量计算转移的目的地址,实现程序的无条件相对转移;操作内容:PC<-(PC)+2PC<-(PC)+rel字节数: 2机器周期:2使用说明:偏移量是8位二进制补码数,可实现程序的双向转移,其转移范围是(PC一126)一(PC+129)。

第3章 51单片机指令系统

第3章 51单片机指令系统
MOV MOV MOV MOV MOV MOV MOV R0, #30H ;R0←30H ,立即寻址 A, @R0 ;A←(R0) ,寄存器间接寻址 R1, A ;R1←A ,寄存器寻址 B, @R1 ;B←R1 ,寄存器间接寻址 @R1, P1 ;(R1)←P1 ,直接寻址 P2, P1 ;P2←P1 ,直接寻址 10H, #20H ;(10H)←20H ,立即寻址
3.1.3 堆栈操作指令
(1)入栈指令:
PUSH direct; SP ← SP+1, (SP) ← (direct)
入栈操作:栈指针SP+1指向栈顶的上 一个空单元,将直接地址direct寻址的单元 内容压入当前SP所指示的堆栈单元中。 (本操作不影响标志位)
例3-3 在中断响应时,SP=09H,数据 指针DPTR的内容为0123H。执行下列指令 后:
MOV @Ri , A ; (Ri)←A MOV @Ri , direct ; (Ri)←(direct) MOV @Ri , data ; (Ri)←#data 上述指令将累加器A,直接地址单元内 容或立即数送到Ri间接寻址单元中。由于内 容较多,下面需要说明:
累加器A是个使用最多的寄存器,MCS-51单 片机以A为中心体系结构。绝大部分指令均需通 过A送到ALU进行运算,结果存于A中,有些指令 仅在A中进行。 直接地址direct ,8位直接地址可寻址0~255个 单元。对于8051则直接寻址内部RAM0~127地址 空间的单元及128~255地址空间的特殊功能寄存 器。这里需注意128~255地址空间很多单元开始 时无定义,对无定义单元进行读/写,则读数不定, 欲写入的数将丢失。 间接寻址@Ri,@间接寻址的符号,是以Ri 的内容作为地址进行寻址,亦即Ri的内容不是操 作数,而是地址。此地址所对应的单元内容才是 所要找的操作数。间接寻址的寻址范围与直接寻 址相同(0~255)。直接寻址单元在编程时就已 明确,而间接寻址单元是在程序运行中明确。

MCS-51单片机指令系统教程(2)

MCS-51单片机指令系统教程(2)

片外数据 存储器 64KB
1,访问片内RAM20H存储单元; MOV A,20H
2,访问片外RAM存储单元; MOV R0,#20H MOVX A,@R0
0000H
3,尽管片内与片外的RAM单元 的00H-FFH地址相重叠但由 于指令的不同不会发生地址
混乱。
片外数据存储器 64KB个字节
返回
2.2.5 变址寻址
由操作码和操作数(或操作数地址)构成指令的结构。
举例:MOV A,#0FFH
ADD A,R0
返回
2.1.2 指令的三种表示形式:
指令的表示形式是识别指令的标志。
1,二进制的表示形式:(以“累加器的内容+08H”为例) 00100100B 操作码 OP (加法) 00001000B 操作数DATA(08H)
乘法指令 16位寄存器DPTR加一
从表中可见,指令的字节数与指令周期不是对等的关系 返回
2.1.4 指令的分类
MCS-51单片机的指令如果按功能划分可以分为五类: 1,数据传送类指令:完成数据在单片机内部之间的传送。
分为8位数和16位两种。除了奇偶位外,指令的执行对 PSW无影响。
2,算术运算指令:用于操作数之间的加、减、乘除运算。 【特点】:多数情况下:操作数之一在累加器A中,结果 也保留在A中,运算结果要影响PSW(进位标志、奇偶和 溢出标志等)。
“机器码”后才能为CPU所识别和执行。 3,三种不同的表示方法适用于不同的场合。
返回
本章内容都以汇编的形式介绍指令系统。
2.1.3 指令的字节数
在MCS-51单片机的指令系统中,因指令操作码和操作数 的不同,指令(在存储器中)长度也各不相同。
分为单字节、双字节和三字节。

51单片机汇编指令总结

51单片机汇编指令总结

51单片机汇编指令总结数据传输指令一.片内RAM数据传输指令1.以累加器A为目的操作数的指令:MOV A , RnMOV A , directMOV A , @RiMOV A , #data2.以寄存器Rn为目的操作数的指令:MOV Rn , AMOV Rn ,directMOV Rn ,data3.以直接地址为目的操作数的指令:MOV direct ,AMOV direct ,RnMOV direct1 ,derect2MOV direct ,@RiMOV direct ,#data4.间接地址为目的操作数的指令:MOV @Ri ,AMOV @Ri ,directMOV @Ri ,#data5.十六位数据传送指令:MOV DPTR , #data16二.累加器A与片外RAM数据传送指令:MOVX A ,@RiMOVX A , @DPTRMOVX @Ri ,AMOVX @DPTR ,A三.查表寻址:MOVC A ,@A+DPTR (先PC←(PC)+1,后A←((A)+(DPTR)))+MOVC A ,@A+PC (先PC←(PC)+1,后A←((A)+(PC)))四.交换指令:1.字节交换指令:XCH A ,RnXCH A ,directXCH A ,@Ri2.半字节交换指令:XCHD A ,@Ri3.累加器半字节交换指令:SWAP A五.栈操作指令:1.PUSH(入栈指令)PUSH direct2.POP(出栈指令)POP direct算术运算指令:一.加法减法指令:1.加法指令:ADD A ,RnADD A ,directADD A ,@RiADD A ,#data2.带进位加法指令:ADDC A ,Rn A←(A)+(Rn)+CYADDC A ,direct A←(A)+(direct)+CYADDC A ,@Ri A←(A)+((Ri))+CYADDC A ,#data A←(A)+(data)+CY3.带借位减法指令:SUBB A ,Rn A←(A)-CY-(Rn)SUBB A ,direct A←(A)-CY-(direct)SUBB A ,@Ri A←(A)-CY-((Ri))SUBB A ,#data A←(A)-CY-#data二.乘法除法指令:1.乘法指令:MUL AB BA←(A) ×(B)高字节放在B中,低字节放在A中2.除法指令:DIV AB A←(A) ÷(B)的商,(B) ←(A) ÷(B)的余数三.加1减1指令:1.加1指令:INC A A←(A)+1INC Rn Rn←(Rn)+1INC direct direct←(direct)+1INC @Ri (Ri) ←((Ri))+1INC DPTR DPTR←(DPTR)+12.减1指令:DEC ADEC RnDEC directDEC @Ri四.十进制调制指令:DA A 调整累加器A的内容为BCD码逻辑操作指令:一.逻辑与、或、异或指令:1.逻辑与指令:ANL A ,RnANL A ,directANL A ,@RiANL A ,#data2.逻辑或这令:ORL A ,RnORL A ,directORL A ,@RiORL A ,#dataORL direct ,AORL direct ,#data3.逻辑异或指令:XRL A ,RnXRL A ,directXRL A ,@RiXRL A ,#dataXRL direct ,AXRL direct ,#data二.清零、取反指令:1.累加器A清零指令:CRL A2.累加器A取反指令:CPL A三.循环位移指令:1.累加器A循环左移指令:RL A2.累加器A循环右移指令:RR A3.累加器A连同进位位循环左移指令:RLC A4. 累加器A连同进位位循环右移指令:RRC A控制转移指令:一.无条件转移指令:1.绝对转移指令:AJMP addr11 (先PC+2,然后将addr11的低十位传给PC,PC的高六位不变)2.长转移指令:LJMP addr16 (用addr16的值替换PC的值)3.相对转移(短转移)指令:SJMP rel(带符号的偏移字节数)(PC+2,再加rel赋值给PC)4.间接转移指令:JMP @A+DPTR (A)+(DPTR) →(PC)二.条件转移指令:1.累加器判零转移指令:JZ rel 先PC+2;后判断,A为0时转移,PC+rel赋值给PC;否则顺序执行JNZ rel 先PC+2,后判断,A不为0时转移,PC+rel赋值给PC;否则顺序执行2.比较转移指令:CJNE 目的操作数,源操作数,relCJNE A,direct,rel 先PC+3传回PC,再比较目的操作数和原操作数CJNE A,#data,rel 目>源时,程序转移,PC+rel传回PC且CY=0CJNE Rn,#data,rel 目=源时,程序顺序执行CJNE @Ri,#data,rel 目<源时,程序转移,PC+rel传回PC且CY=13.减一非0指令:DJNZ Rn,rel 先PC\+2,Rn-1,当Rn为0时程序顺序执行,否则PC+rel传回PCDJNZ direct,rel 先PC+3,direct-1,direct为0时程序顺序执行,否则PC+rel 传回PC二.子程序调用、返回指令:1.绝对调用指令ACALL:ACALL addr11 先PC+2,SP+1将PC的低八位存入SP;SP+1,将PC的高八位存入SP。

第3章 MCS-51指令系统

第3章 MCS-51指令系统

16
MCS-51单片机指令系统
MCS-51单片机指令系统包括111条指令 按功能可以划分为以下5类:
1. 数据传送和交换指令(29条)
2. 算术运算指令(24条) 3. 逻辑运算指令(24条) 4. 控制转移指令(17条) 5. 位操作指令(17条)
17

数据传送和交换类指令主要有以下几种:
1. 2. 3.

30H
Eg:MOV 30H,#33H 33H
30H
XX 30H
33H
30H
31H
Eg:MOV 30H,31H
55H
XX
55H
25
A

30H XX
地址
30H 33H
Eg:MOV 30H, A
33H
R0
Eg:MOV 30H,@R0
55H
取出
30H 78H 30H
55H
R3
78H
30H XX

55H
MOV A , 30H
XX 55H
30H
A
6
3、寄存器寻址
寄存器寻址是指将操作数存放于寄存器中,寄存器包括工作寄 存器R0~R7、累加器A、通用寄存器B、地址寄存器DPTR等。 数据存放在R0~R7中的某个通用寄存器内,或者放在某个专用 寄存器中。 e.g.: MOV A,R7 ADD A,R0
DPTR
2000H
DPTR 2000H
XXXX
Eg:将数据指针DPTR指向存于ROM中的表格首地址。
MOV DPTR,#TABLE
27
三、片外数据传递指令
使用DPTR和Ri进行间接寻址 MOVX A, @DPTR ;A ←((DPTR))片外 MOVX A,@Ri ;A ←((Ri))片外 MOVX @DPTR,A ;(DPTR)片外←(A) MOVX @Ri,A ;(Ri)片外←(A) 注意: 该指令用于在单片机和外部RAM、扩展I/O的数据传送; 使用Ri时,只能访问低8位地址为00H~FFH地址段; 使用DPTR时,能访问0000H ~ FFFFH地址段。

第3章MCS-51单片机指令系统

第3章MCS-51单片机指令系统

第3章MCS-51单片机指令系统3.1概述3.1.1指令格式3.1.2指令的三种表示形式3.1.3指令的字节数1. 单字节指令(49条)图3-1 MOVA,Rn指令的格式2单片机原理及其接口技术(第2版)2. 双字节指令(46条)3. 三字节指令(16条)3.1.4指令的分类1. 数据传送指令(28条)2. 算术运算指令(24条)3. 逻辑操作和环移指令(25条)4. 控制转移指令(17条)5. 位操作指令(17条)3.1.5指令系统综述1. 指令系统中所用符号的说明2. 指令对标志位的影响3.2寻址方式3.2.1寄存器寻址图3-2寄存器寻址示意图单片机原理及其接口技术(第2版) 3 3.2.2直接寻址图3-3直接寻址示意图3.2.3立即寻址3.2.4寄存器间址图3-4寄存器间址寻址示意图3.2.5变址寻址图3-5变址寻址示意图4单片机原理及其接口技术(第2版)3.2.6相对寻址图3-6相对寻址示意图3.2.7位寻址3.3数据传送指令3.3.1内部数据传送指令(15条)1. 立即寻址型传送指令2. 直接寻址型传送指令3. 寄存器寻址型传送指令4. 寄存器间址型传送指令5. 内部数据传送指令的使用图3-7 8×C552/8051指令的数据传送方式单片机原理及其接口技术(第2版) 5 3.3.2外部数据传送指令(7条)1. 16位数传送指令2. 外部ROM的字节传送指令图3-8 0~9平方值表3. 外部RAM的字节传送指令3.3.3堆栈操作指令(2条)图3-9例3.8的堆栈变化示意图6单片机原理及其接口技术(第2版)3.3.4数据交换指令(4条)3.4算术与逻辑运算和移位指令3.4.1算术运算指令(24条)1. 加法指令2. 减法指令3. 十进制调整指令4. 乘法和除法指令3.4.2逻辑运算指令(20条)1. 逻辑与运算指令2. 逻辑或指令3. 逻辑异或指令4. 累加器清零和取反指令3.4.3移位指令(5条)单片机原理及其接口技术(第2版)7图3-10例3.26附图3.5控制转移和位操作指令3.5.1控制转移指令(17条)1. 无条件转移指令图3-11 AJMP指令转移范围8单片机原理及其接口技术(第2版)图3-12例3.29附图图3-13带符号数的比较方法3. 子程序调用和返回指令图3-14二级子程序嵌套及断点地址存放单片机原理及其接口技术(第2版)9图3-15例3.33附图10单片机原理及其接口技术(第2版)4. 空操作指令3.5.2位操作指令(17条)1. 位传送指令2. 位置位和位清零指令3. 位运算指令4. 位控制转移指令习题与思考题3.1指令通常有哪三种表示形式?各有什么特点?3. 2 MCS-51指令按功能可以分为哪几类?每类指令的作用是什么?3. 3 MCS-51共有哪七种寻址方式?各有什么特点?3. 4指出下列每条指令源操作数的寻址方式和功能。

51单片机数据类型int,float,指针所占字节数

51单片机数据类型int,float,指针所占字节数


请求出错错误代码400请尝试刷新页面重试
51单片机数据类型 int,float,指针所占字节数
1.int===2个字节 2.sfr===特殊功能寄存器,也是一种扩充数据类型,占用1个内存单元,利用它可以访问51单片机内的所有特殊功能寄存器。 sfr P1 = 0x90;/////////这一句定义P1为P1端口在片内的寄存器。 3.sfr16===16位特殊功能的寄存器。用于定时器T0,T1 4.sbit===可录址位,也是一种扩充数据类型。利用它可访问芯片内部RAM中的可寻址位或特殊功能寄存器的可寻址位。 sfr P1 = 0x90;/////////因P1端口的寄存器是可寻址位的,所以我们可以定义 sbit P1_1 = P1^1;///////P1_1为P1中的P1.1引脚 ////////==>sbit P1_1 = 0x91;

第三章MCS51的指令系统

第三章MCS51的指令系统

3.4.1 MCS-51数据传送指令
[1]. 以累加器A为目的操作数类指令(4条) 这4条指令的作用是把源操作数指向的内容送到累加器A。有直接、
立即数、寄存器和寄存器间接寻址方式:
MOV A,direct
(direct)→(A)直接单元30H
MOV A,0A2H
§3.1 概述
7种寻址方式,111条指令
指令所占用空 间(字节数)
指令执行周期 (运算速度)
单字节指令:49条 双字节指令:45条 三字节指令:17条
单周期指令:64条 双周期指令:45条 四周期指令:2 条
试问
1 如果一条指令执行时间为3个机器周 期,那么需要经历多少个时钟周期?
2 如果一条指令执行时使用了2us,而 晶振使用的是12MHz,请问执行这条指 令需要多少个机器周期?
(A)+((Ri))+(C)→(A) 累加器A中的内容与工作寄存 器Ri指向地址单元中的内容、连同进位位相加,结果存在A中
3.4.2 MCS-51算术运算指令
[3]. 带借位减法指令(4条)
这组指令包含立即数、直接地址、间接地址及工作寄存器与累加器A连同借位 位C内容相减,结果送回累加器A中。
3.4.1 MCS-51数据传送指令
[2]. 以寄存器Rn为目的操作数的指令(3条)
这3条指令的功能是把源操作数指定的内容送到所选定的工作寄存器 Rn中。有直接、立即和寄存器寻址方式:
MOV Rn, direct (data)→(Rn) 直接寻址单元中的内容送到寄存器Rn中 MOV R4,37H
**补充知识
MCS51系列单片机为复杂指令单片机CISC。目前单片机大 量使用的是精简指令集RISC结构单片机.

第三章MCS-51指令系统

第三章MCS-51指令系统
第三章 MCS-51单片机指令系统
3.1 概述
3.2
3.3
寻址方式
MCS-51的指令系统
3.4
伪指令
3.1
概述
指令:使计算机完成某种操作的命令。 指令系统 :计算机能够执行的全部操作所对应的指 令集合。 机器语言: 采用二进制编码表示指令,是计算机能够直 接识别和执行的语言。 汇编语言: 采用助记符 、符号、数字来表示指令的程序 语言,它与机器语言指令时一一对应的。
如果我们分别向DPH,DPL送数,则结果也一样。
如下面两条指令: 则就相当于执行了 MOV DPH,#35H MOV DPTR,#3512H。 MOV DPL,#12H。
(6) 累加器A与片外RAM之间的数据传递类指令(4条)
MOVX A,@Ri MOVX @Ri,A MOVX A,@DPTR MOVX @DPTR,A 说明: 1.在51中,与外部存储器RAM打交道的只可以是A累加器。所 有需要送入外部RAM的数据必需要通过A送去,而所有要读入的外 部RAM中的数据也必需通过A读入。 在此我们可以看出内外部RAM的区别了,内部RAM间可以直接 进行数据的传递,而外部则不行。 比如,要将外部RAM中某一单元(设为0100H单元的数据)送 入另一个单元(设为0200H单元),也必须先将0100H单元中的内 容读入A,然后再送到0200H单元中去。
MOV B,R0
PUSH ACC
;R0→B,R0为寄存器寻 址,B为直接寻址。
;A的内容压入堆栈
3.2.4
寄存器间接寻址
例:MOV A, @R0
• 以寄存器中内容为地址,以该地址中内容为操作数的
寻址方式。间接寻址的存储器空间包括内部RAM和
外部RAM。 • 能用于寄存器间接寻址的寄存器有R0,R1,DPTR, SP。其中R0、R1必须是工作寄存器组中的寄存器。 SP仅用于堆栈操作。

51单片机C语言指令

51单片机C语言指令
sfr 1 字节 0~255
sfr16 2 字节 0~65535
有符号整形 (signed)ind 16位 -32767-+32767
(signed)short 16位 -32767-+23767
(signed)long 32位 -2147483648-+214748364
简单的单片机C程序要有什么
1)头文件 (#include<re51.h>)
2)主函数 (void main)
3)执行部分
C语言中常用的语句
1)选择语句(if-else)
2)循环语句(while)
3)循环语句(do while)
4)循环语句(for( ; ; ))
C-51的运算符
do-while 循环语句
C-51的数据类型
sbit(位)
把变量另外取名#define a P2 (把P2另外取名为a)
基本数据类型
bit 1 字节 0 或 1
signed char 1 字节 -128~+127
unsigned char 1 字节 0~255
signed int 2 字节 -32768~+32867
unsigned int 2 字节 0~65535
signed long 4 字节 -2147483648~+2147483647
unsigned long 4 字节 0~4294967295
float 4 字节 ±1.176E-38~±3.40E+38
指针 1~3 字节 对象地址
sbit 1 位 0 或 1
== != (等于 不等于)

常见51单片机指令及详解

常见51单片机指令及详解

常见51单片机指令及详解数据传递类指令(1)以累加器为目的操作数的指令MOV A,RnMOV A,directMOV A,@RiMOV A,#data第一条指令中,Rn代表的是R0-R7。

第二条指令中,direct就是指的直接地址,而第三条指令中,就是我们刚才讲过的。

第四条指令是将立即数data送到A中。

下面我们通过一些例子加以说明:MOV A,R1 ;将工作寄存器R1中的值送入A,R1中的值保持不变。

MOV A,30H ;将内存30H单元中的值送入A,30H单元中的值保持不变。

MOV A,@R1 ;先看R1中是什么值,把这个值作为地址,并将这个地址单元中的值送入A中。

如执行命令前R1中的值为20H,则是将20H单元中的值送入A中。

MOV A,#34H ;将立即数34H送入A中,执行完本条指令后,A中的值是34H。

(2)以寄存器Rn为目的操作的指令MOV Rn,AMOV Rn,directMOV Rn,#data这组指令功能是把源地址单元中的内容送入工作寄存器,源操作数不变。

(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。

谈谈51单片机的指令字节数

谈谈51单片机的指令字节数

谈谈51单片机的指令字节数51单片机是一种广泛应用于嵌入式系统中的微控制器。

在进行单片机编程时,了解指令字节数是非常重要的。

本文将探讨51单片机的指令字节数及其相关内容。

一、引言在嵌入式系统中,单片机是非常重要的组成部分。

51单片机是由Intel公司开发的一款经典的8位微控制器。

了解51单片机的指令字节数,对于理解其原理、编写高效的程序以及优化系统性能至关重要。

二、什么是指令字节在计算机系统中,指令是用于执行特定操作的基本命令。

在51单片机中,每个指令被编码为一个字节(8位)。

指令字节数指的是每个指令所占用的字节数。

三、指令字节数的确定方法51单片机的指令字节数由其架构和指令集决定。

具体而言,它由单片机的指令集大小和指令编码长度两个因素共同决定。

1. 指令集大小指令集是单片机支持的所有指令的集合。

不同的单片机具有不同的指令集大小。

51单片机的指令集大小为2^8,即256个指令。

2. 指令编码长度指令编码长度指的是将每个指令编码为二进制形式所使用的位数。

51单片机的指令编码长度为8位,即一个字节。

通过以上两个因素,我们可以得出51单片机的指令字节数为1字节。

四、指令字节数的意义了解51单片机的指令字节数对于单片机编程至关重要。

指令字节数的大小直接影响到存储器空间的利用以及程序运行的效率。

1. 存储器空间利用由于51单片机的指令字节数为1字节,因此每个指令占用的存储器空间较小。

这使得我们能够更好地利用有限的存储器资源,充分发挥单片机的功能。

2. 程序运行效率指令字节数的大小也会直接影响程序运行的效率。

由于51单片机的指令字节数为1字节,每个指令的执行时间相对较短,可以更快地完成相应的操作。

这对于需要高效执行的应用程序非常重要。

五、如何优化程序在编写51单片机的程序时,我们可以通过一些优化方法来提高程序的效率。

1. 减少指令数目通过合理的算法设计和程序优化,可以减少执行的指令数目,从而提高程序的效率。

第三章 MCS-51单片机指令系统

第三章 MCS-51单片机指令系统

位操作类指令(17条)
位操作指令实际就是布尔处理机的指令系统,这 为开关量控制提供了非常有效的手段。
位传送
位置位复位
位运算 位控制转移
位数据传送指令(2条)
MOV MOV
C , bit bit,C
例:片内RAM中(20H)=7FH,执行指令
MOV C,07H 则C=0
位置位复位指令(4条)
调用与返回指令组(4条)
长调用指令 绝对调用指令 子程序返回指令
LCALL addr16 ACALL addr11 RET
中断服务程序返回指令 RETI
空操作指令(1条)
NOP
例:把2000H开始的外部RAM单元中的数据送到3000H
开始的外部RAM单元中,数据个数存放在内部RAM 35H单元。
ANL(ORL,XRL) A , { #data ; direct ; @Ri ; Rn }
2. 直接地址单元与累加器A、立即数之间的逻辑操作(6条)
ANL(ORL,XRL) direct , { A ; #data }
清零与取反指令(2条)
清零: 取反:
CLR A CPL A
循环移位指令(4条)
2. 带进位加法指令(4条) ADDC A , { #data ; direct ; @Ri ; Rn }
3. 带借位减法指令(4条) SUBB A , { #data ; direct; @Ri ; Rn }
影响所有标志位状态
例: 执行指令 MOV A , #0C2H ADD A , #0A9H 对PSW相应状态位的影响如下 1 1 1
3.2 MCS-51指令分类介绍
共分5大类,111条指令。
1.数据传送类指令(29条) 2.算术运算类指令(24条) 3.逻辑运算及移位类指令(24条) 4.控制转移类指令(17条) 5.位操作类指令(17条)

1解:8051的指令系统由111条指令组成如果按字节数分类

1解:8051的指令系统由111条指令组成如果按字节数分类

1001.解:8051的指令系统由111条指令组成。

如果按字节数分类,有49条单字节指令46条双字节指令和16条三字节指令,以单字节指令为主;如果按照指令执行时间分类,有64条单周期指令、45条双周期指令和2条四周期指令,以单周期指令为主。

8051的指令系统具有以下特点:(1)存储效率高、执行速度快,可以进行直接地址到直接地址的数据传送,能把一个并行I/O 口中的内容传送到内部RAM 单元中而不必经过累加器A 或工作寄存器Rn 。

这样可以大大提高传送速度和缓解累加器A 的瓶颈效应。

(2)用变址寻址方式访问程序存储器中的表格,将程序存储器单元中的固定常数或表格字节内容传送到累加器A 中。

这为编成翻译算法提供了方便。

(3)在算术运算指令中设有乘法和除法指令(4)指令系统中一些对I/O 口进行操作的指令具有“读——修改——写”的功能。

这一功能指:在执行读锁存器的指令时,CPU 首先完成将锁存器的值通过缓冲器BUF2度入内部,进行修改、改变,然后重新写到锁存器中去。

这种类型指令包含所有的逻辑操作和位操作指令。

(5)8051单片机内部有一个布尔处理器,对为地址空间具有丰富的位操作指令。

布尔操作类指令有17条,包括布尔传送指令、布尔状态控制指令、布尔逻辑操作指令、布尔条件转移指令。

2.解:MCS-51单片机指令系统按功能可分为5类:(1)数据传送指令 (2)算术运算指令(3)逻辑运算和移位指令 (4)控制转移指令(5)位操作指令MCS-51单片机的指令系统提供了七种寻址方式,其对应的寻址范围如下表:3.解: 访问特殊功能寄存器,应采用直接寻址、位寻址方式。

访问外部数据存储器,应采用寄存器间接寻址方式。

在0~255B 范围内,可用寄存器R0、R1间接寻址:MOVX A ,@R0 或 MOVX A ,@R1寻址方式 使用的变量 寻址范围 立即寻址 程序存储器直接寻址内部RAM 低128个字节; 特殊功能寄存器SFR寄存器寻址 R0~R7;A 、B 、DPTR 、C寄存器间接寻址 @R0、@R1、SP 内部RAM 、堆栈指针SP @R0、@R1、@DPTR 外部RAM变址寻址 @A+PC 、@A+DPTR 程序存储器 相对寻址 PC+偏移量 程序存储器位寻址内部RAM 低128B 位寻址区 可位寻址的特殊功能寄存器位2MOVX @R0,A 或MOVX @R1,A在0~64KB范围内,可用16位寄存器DPTR间接寻址:MOVX A,@DPTRMOVX @DPTR,A4.解:这条指令是在进行BCD码加法运算时,跟在“ADD”和“ADDC”指令之后,用来对BCD码的加法运算结果自动进行修正的,使其仍为BCD码表达形式。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
CLR C
CALL BSUB
MOV 40H, A
.
.
.
A, #9AH
SUBB A, @R0
ADD A, @R1
DA A
INC R0
INC R1
程序分析
50ms延时子程序:
DEL:MOV R7,#200 ①
DEL1:MOV R6,#125 ②
DEL2:DJNZ R6,DEL2 ③
DJNZ R7,DEL1 ④
RET ⑤
1+(1*200)+(2*125*200)+(2*200)+2
=(2*125+3)*200+3 ⑥
2、8位立即数占用一个字节,16位立即数占用两个字节。
3、8位操作数地址占用一个字节,16位操作数地址占用两个字节。
4、CPU内部的各种寄存器不占用指令字节,如A, B, R0, R1, DPTR等。
现在就可以判断51的指令占用的字节数了:
MCS-51 单片机的十进制调整指令 (DA A) 只能放在加法指令之后,它对减法不起作用。
BCD 码的减法,必须变换成加法进行,才能使用 DA A 指令进行十进制调整。
“补数”的问题。
15 分和正拨 45 分,效果是相同的。
60-15=45 求出 15 对 60 的补数 45。
(50H) + [100 - (60H)]
100,又等效写成 9AH,不信,你对它 DA A 试试,马上就是 100H,这就是 100 的 BCD码,

“减数求补”的问题,是 MCS-51 单片机的汇编语言中,特有的问题。
BCD 码相减,如果想要得到 BCD 码形式的结果,就应该进行十进制调整。
=998033μs≈1s
(2*第一层循环+3)*第二层循环+3]*第三层循环+3⑨
例3仍以1秒延时为例
DEL:MOV R7,#10 1指令周期1
DEL1:MOV R6,#0FFH 1指令周期10
DEL2:MOV R5,#80H 1指令周期255*10=2550
s延时,需要在返回指令RET前再添加一些指令让它把1567μs的延时完
R7,$ ;R7内容减1不为0,则再次执行本指令;为0则往下执行,
μs。
51单片机汇编延时程序算法详解
CPU执行一条指令所需要的时间称为指令周期,它是以机器周期为单位的,
×(1/12000000)=1μs。
87H + 66H = EDH
DA A后得:153H
把进位 1 丢弃,结果就是 53 的 BCD 码 53H。
DA A也会改变PSW中的进位标志位!
示例:如果累加器中的内容为56H(01010110B),表示十进制数56的BCD
MOV 07H, #07H ;这是三字节指令,MOV占用一个字节,8位地址07H占用一个
8位立即数#07H占用一个字节。
BCD 码减数求补的问题
ORG 0100H
MOV R1, #50H
MOV R0, #60H
谈谈51单片机延时子程序
但一些读者在学习中不知道延时程序怎么编程,
那么执行一个机器周期就只需要1μs;如果采用的是6MHz的晶
μs。
(执行这条指令只需一个机器周期),双周期指令(执行这
,四周期指令(执行这条指令需要四个机器周期)。除了乘、除
MOV
R7,#80H;将数据80H送到寄存器R7,这时寄存器R7里面存
PC。
PC
Program Counter),是程序计数器,是一个16位的专用寄存器,用来存放下一条指
。当CPU 要
PC的内容首先送至地址总线上,然后再从存储器中取出指令,取指令后,PC
1,指向下一条指令的地址(这句话很关键)。
ACALL
它本身占2个字节的存储单元。为了保证子程序返回后程序按
PC内容要先加2,指向ACALL指令后的单元,以便顺序执行。
24的BCD码,也就是56、67及进位标志之和的后两位数字。DA
1,这表示在进行十进制加法时,发生了溢出。56、67以及1
124。
!!呵呵!!也就是说,一旦有中断,硬件会
而跳往中断入口地址,在中断入口地址处有 中断处理函数 ;等

,人家厂商做的,没办法,,更可恨的是,把中断入口地址从0003H 开
码的运算之后,应(使用 DA A指令)进行十进制调整,将运算结果修正为 BCD 码;
MCS-51 单片机的 DA A 指令只能放在加法之后,它对减法不起作用。
BCD 码的减法必须变换成加法,才能用 DA A 指令进行十进制调整。
15分,和正拨45分,效果相同的方法,可将:
(50H) - (60H)
序介绍:单片机通过DAC0832转换在LM358的7脚输
三角波。实际应用如:函数波形发生器。
序实例(0832shan.asm):
选通地址
通过上升和下降来产生三角波///////////////////
电压随时间上升///////////////////////////////
电压随时间下降///////////////////////////////
MOV A, R0 ; 这是单字节指令,其中MOV占用一个字节,A和R0是CPU内
MOV A, #07H ;这是双字节指令,其中MOV占用一个字节,8位立即数#07H占用
MOV DPTR, #0106H ;这是三字节指令, MOV占用一个字节,16位立即数#0106H
3的内容为67H(01100111B),表示十进制数67的BCD码。进位标志
1,则指令
ADDC A,R3
DA A
先执行标准的补码二进制加法,累加器A的值变为0BEH,进位标志和
接着,DA执行十进制调整,将累加器A的内容变为24H(00100100B),
51单片机的指令字节数
现在的单片机程序大多都用C语言来编写了,汇编看起来有点OUT了。可是有时候汇编却很有用,因为
MCS-51单片机的指令的字节数。
汇编语言的语句的格式为:
标号段: 操作码段 第一操作数,第二操作数 ;注释段 (如
,载波调制信号用载波的不同调制状态来表示二进制的信号,如单相调
,分别表示"0"和"1", 四相调制有4个状态 表示二位二进制数"00", "01", "10"和
,八相调制有3位,以此类推. 因此,单相调制的波特率和比特率相等,四相调制的
2倍,八相是3倍.....kpt希望采纳我的
.1 利用dac0832产生三角波
利用dac0832产生方波
序介绍:程序介绍:单片机通过DAC0832转换在
的7脚输出方波。实际应用如:函数波形发生器。
序实例(0832fan.asm):
通过高低电平地的变化来输出方波///////////
向选通地址送低电平地
向选通地址送高电平
延时,通过改变它的大小
以改变占空比
利用dac0832产生正弦波
μs。
1秒延时子程序:
DEL:MOV R7,#10 ①
DEL1:MOV R6,#200 ②
DEL2:MOV R5,#248 ③
DJNZ R5,$ ④
DJNZ R6,DEL2 ⑤
DJNZ R7,DEL1 ⑥
RET ⑦
对每条指令进行计算得出精确延时时间为:
=[(2*248+3)*200+3]*10+3 ⑧
CPL C
RET
9AH 的作用是什么,能不能换成别的数!
BCD 码减法程序。
回答: | 五级 2009-8-29 09:58
MCS-51 单片机的汇编语言,很多人都不懂的。
(50H)-(60H)-->(40H) 的 BCD 码减法运算;并且对源数据的地址指针进行了修正。
,每隔7 个单元 放一个 中断入口;;;依次是:
000BH——0013H——001B——0023H
,是你配置的(INT0,INT1,T0,T1,串口)中断类型;
硬件 自动跳到,不归你管啊!!!要是隔着的那七个地址单
写中断处理函数怎么办呢???那就先跳转到另一个空地上,等做好事情后再 调回
,之后 再跳回到 程序停止的 地方!!!呵呵!!!!!不知明白了没?????关于
NOP
DJNZ
R7,KK ;将寄存器R7的内容减1并判断寄存器R7里的内容减
则转移到地址标号为KK的地方;如果为0则执行下一条指
μs)
程序总共所需时间:1+10+2560+330240+660480+5120+20+2=998433μs≈1s
μs,还差1562产生梯形波
序介绍:程序介绍:单片机通过DAC0832转换在
的7脚输出梯形波。实际应用如:函数波形发生器。
序实例(0832ti.asm):
选通地址
延时
每次以19H的梯度增加
梯度等待的时间
循环
单片机在执行短调用指令(ACALL)时,在调用操作之前为什么PC要先加2?
“和”就是原来要求出的“差”了。
DA A 指令进行调整了。
100,可等效写成 9AH,当对它进行 DA A 调整后,它就会变成 100H。
和 100H,都是 100 的 BCD 码。
“补数”和求“补码”都是相同的。
87 - 34 = 53
9AH -34H = 66H
相关文档
最新文档