首页 > 芯片 > 半导体 > 51单片机有多少条语句,include

51单片机有多少条语句,include

来源:整理 时间:2023-07-31 13:48:52 编辑:亚灵电子网 手机版

1,includeintrinsh

这个头文件主要是包含了有关51单片机的几条汇编语句的C语言调用接口,是直接编译成对应的汇编语句的。比如_nop_()函数就代表汇编语言中的NOP,在C语言编程时编写精确的短延时时使用_nop_()函数。

includeintrinsh

2,51单片机内部存储器能存多少条c语言的程序

汇编指令一条通常占1~3个字节,与你的具体指令有关,例如INCACC占1字节、MOVA,30H占2字节、LJMP××就得占3个字节。短程序对照指令表一个一个计算可知,长的通常估算就用2字节乘指令行数得个大概值。C语言,可以说编译出来的程序代码大小与写的行数几乎没有关系了,将C程序编译看反汇编就可知道,大小由反汇编出来的指令数决定。比方说C语言中开方运算a=squr(b);仅此一行就可汇编成近千条指令。这就是为什么常说的C语言不如汇编简洁的原因。至于51单片机存多少条指令还得看你用芯片的型号。51系列门类很多,初学者常用的ATMEL公司的AT89C51/AT89S51的程序存储区容量是4K字节的,AT89C52/AT89S52是8K的;若程序量较大且超过片内容量又不想片外扩容的话,可用WINBOND华邦公司的W78E54(16K)/W78E58(32K),华邦的片在市场上还是很好找的。更多电子问题请关注我!zhidao_ceo竭诚为您解答!

51单片机内部存储器能存多少条c语言的程序

3,51单片机执行一条语句的时间是多久

得看是什么语句,也要看单片机晶振是多少,另外是多少T的。 通常对12M晶振,12T(一个机器周期是12个时钟周期)的51单片机,有的指令(汇编)是1个机器周期,有的是2个,还有两条指令是4个(乘,除),这样对应的就需要1us,2us,4us 如果是C的语句,就要看编译成的机器指令是什么样的

51单片机执行一条语句的时间是多久

4,51单片机共有多少指令

MCS-51单片机的指令集1、数据传送类指令助记符 功能说明 字节数 振荡周期 MOV A,Rn 寄存器内容送入累加器 1 12MOV A,direct 直接地址单元中的数据送入累加器 2 12MOV A,@Ri 间接RAM中的数据送入累加器 1 12MOV A,#data8 8位立即数送入累加器 2 12MOV Rn,A 累加器内容送入寄存器 1 12MOV Rn,direct 直接地址单元中的数据送入寄存器 2 24MOV Rn,#data8 8位立即数送入寄存器 2 12MOV direct,A 累加器内容送入直接地址单元 2 12MOV direct,Rn 寄存器内容送入直接地址单元 2 24MOV direct,direct 直接地址单元中的数据送入直接地址单元 3 24MOV direct,@Ri 间接RAM中的数据送入直接地址单元 2 24MOV direct,#data8 8位立即数送入直接地址单元 3 24MOV @Ri,A 累加器内容送入间接RAM单元 1 12MOV @Ri,direct 直接地址单元中的数据送入间接RAM单元 2 24MOV @Ri,#data8 8位立即数送入间接RAM单元 2 12MOV DPTR,#data16 16位立即数地址送入地址寄存器 3 24MOVC A,@A+DPTR 以DPTR为基地址变址寻址单元中的数据送入累加器 1 24MOVC A,@A+PC 以PC为基地址变址寻址单元中的数据送入累加器 1 24MOVX A,@Ri 外部RAM(8位地址)送入累加器 1 24MOVX A,@DPTR 外部RAM(16位地址)送入累加器 1 24MOVX @Ri,A 累加器送入外部RAM(8位地址) 1 24MOVX @DPTR,A 累加器送入外部RAM(16位地址) 1 24PUSH direct 直接地址单元中的数据压入堆栈 2 24POP DIRECT 堆栈中的数据弹出到直接地址单元 2 24XCH A,Rn 寄存器与累加器交换 1 12XCH A,direct 直接地址单元与累加器交换 2 12XCH A,@Ri 间接RAM与累加器交换 1 12XCHD A,@Ri 间接RAM与累加器进行低半字节交换 1 122、算术操作类指令助记符 功能说明 字节数 振荡周期ADD A,Rn 寄存器内容加到累加器 1 12ADD A,direct 直接地址单元加到累加器 2 12ADD A,@Ri 间接RAM内容加到累加器 1 12ADD A,#data8 8位立即数加到累加器 2 12ADDC A,Rn 寄存器内容带进位加到累加器 1 12ADDC A,dirct 直接地址单元带进位加到累加器 2 12ADDC A,@Ri 间接RAM内容带进位加到累加器 1 12ADDC A,#data8 8位立即数带进位加到累加器 2 12SUBB A,Rn 累加器带借位减寄存器内容 1 12SUBB A,dirct 累加器带借位减直接地址单元 2 12SUBB A,@Ri 累加器带借位减间接RAM内容 1 12SUBB A,#data8 累加器带借位减8位立即数 2 12INC A 累加器加1 1 12INC Rn 寄存器加1 1 12INC direct 直接地址单元内容加1 2 12INC @Ri 间接RAM内容加1 1 12INC DPTR DPTR加1 1 24DEC A 累加器减1 1 12DEC Rn 寄存器减1 1 12DEC direct 直接地址单元内容减1 2 12DEC @Ri 间接RAM内容减1 1 12MUL A,B A乘以B 1 48DIV A,B A除以B 1 48DA A 累加器进行十进制转换 1 123、逻辑操作类指令助记符 功能说明 字节数 振荡周期ANL A,Rn 累加器与寄存器相“与” 1 12ANL A,direct 累加器与直接地址单元相“与” 2 12ANL A,@Ri 累加器与间接RAM内容相“与” 1 12ANL A,#data8 累加器与8位立即数相“与” 2 12ANL direct,A 直接地址单元与累加器相“与” 2 12ANL direct,#data8 直接地址单元与8位立即数相“与” 3 24ORL A,Rn 累加器与寄存器相“或” 1 12ORL A,direct 累加器与直接地址单元相“或” 2 12ORL A,@Ri 累加器与间接RAM内容相“或” 1 12ORL A,#data8 累加器与8位立即数相“或” 2 12ORL direct,A 直接地址单元与累加器相“或” 2 12ORL direct,#data8 直接地址单元与8位立即数相“或” 3 24XRL A,Rn 累加器与寄存器相“异或” 1 12XRL A,direct 累加器与直接地址单元相“异或” 2 12XRL A,@Ri 累加器与间接RAM内容相“异或” 1 12XRL A,#data8 累加器与8位立即数相“异或” 2 12XRL direct,A 直接地址单元与累加器相“异或” 2 12XRL direct,#data8 直接地址单元与8位立即数相“异或” 3 24CLR A 累加器清0 1 12CPL A 累加器求反 1 12RL A 累加器循环左移 1 12RLC A 累加器带进位循环左移 1 12RR A 累加器循环右移 1 12RRC A 累加器带进位循环右移 1 12SWAP A 累加器半字节交换 1 124、控制转移类指令 助记符 功能说明 字节数 振荡周期ACALL addr11 绝对短调用子程序 2 24LACLL addr16 长调用子程序 3 24RET 子程序返回 1 24RETI 中断返回 1 24AJMP addr11 绝对短转移 2 24LJMP addr16 长转移 3 24SJMP rel 相对转移 2 24JMP @A+DPTR 相对于DPTR的间接转移 1 24JZ rel 累加器为零转移 2 24JNZ rel 累加器非零转移 2 24CJNE A,direct,rel 累加器与直接地址单元比较,不等则转移 3 24CJNE A,#data8,rel 累加器与8位立即数比较,不等则转移 3 24CJNE Rn,#data8,rel 寄存器与8位立即数比较,不等则转移 3 24(相等则执行本指令的下一条)CJNE @Ri,#data8,rel 间接RAM单元,不等则转移 3 24(但有时还想得知两数比较之后哪个大,哪个小,本条指令也具有这样的功能,如果两数不相等,则CPU还会反映出哪个数大,哪个数小,这是用CY(进位标志位)来实现的。如果左边的数(A,Rn,@Ri)大或者等于右边的数(direct,#date8),则CY=0;否则CY=1)DJNZ Rn,rel 寄存器减1,非零转移 3 24DJNZ direct,rel 直接地址单元减1,非零转移 3 24NOP 空操作 1 12控制转移指令共有17条,可分为“无条件转移指令” “有条件转移指令” “子程序调用指令” 及 “返回指令”。5、布尔变量操作类指令助记符 功能说明 字节数 振荡周期CLR C 清进位位 1 12CLR bit 清直接地址位 2 12SETB C 置进位位 1 12SETB bit 置直接地址位 2 12CPL C 进位位求反 1 12CPL bit 直接地址位求反 2 12ANL C,bit 进位位和直接地址位相“与” 2 24ANL C,/bit 进位位和直接地址位的反码相“与” 2 24ORL C,bit 进位位和直接地址位相“或” 2 24ORL C,/bit 进位位和直接地址位的反码相“或” 2 24MOV C,bit 直接地址位送入进位位 2 12MOV bit,C 进位位送入直接地址位 2 24JC rel 进位位为1则转移(CY=O不转移,=1转移) 2 24JNC rel 进位位为0则转移(和上面相反) 2 24JB bit,rel 直接地址位为1则转移 3 24JNB bit,rel 直接地址位为0则转移 3 24JBC bit,rel 直接地址位为1则转移,该位清零 3 24伪指令助记符 功能说明ORG 设置程序起始地址END 标志源代码结束EQU 定义常数SET 定义整型数DATA 给字节类型符号定值BYTE 给字节类型符号定值WROD 给字类型符号定值BIT 给位地址取名ALTNAME 用自定义名取代保留字DB 给一块连续的存储区装载字节型数据DW 给一块连续的存储区装载字型数据DS 预留一个连续的存储区或装入指定字节。INCLUDE 将一个源文件插入程序中TITLE 列表文件中加入标题行NOLIST 汇编时不产生列表文件NOCODE 条件汇编时,条件为假的不产生清单

5,单片机有多少条指令分别是什么意思

指的是汇编指令集MOV r,mSUB r1,r2这些都是指令51内核单片机一共有111条汇编指令
简单程序如下: sbit d0 = p1^1; int main(void) { while(1) { d0 = ~ d0; //把单片机p1.1端口数据取反, 1变成0或者0变成1 } }

6,MCS51系列单片机指令系统共有111条指令谁能具体的列出这111条

MCS-51数据传送指令 数据传送指令共有29条,数据传送指令一般的操作是把源操作数传送到目的操作数,指令执行完成后,源操作数不变,目的操作数等于源操作数。如果要求在进行数据传送时,目的操作数不丢失,则不能用直接传送指令,而采用交换型的数据传送指令,数据传送指令不影响标志C,AC和OV,但可能会对奇偶标志P有影响。 [1]. 以累加器A为目的操作数类指令(4条) 这4条指令的作用是把源操作数指向的内容送到累加器A。有直接、立即数、寄存器和寄存器间接寻址方式: MOV A,data ;(data)→(A) 直接单元地址中的内容送到累加器A MOV A,#data ;#data→(A) 立即数送到累加器A中 MOV A,Rn ;(Rn)→(A) Rn中的内容送到累加器A中 MOV A,@Ri ;((Ri))→(A) Ri内容指向的地址单元中的内容送到累加器A [2]. 以寄存器Rn为目的操作数的指令(3条) 这3条指令的功能是把源操作数指定的内容送到所选定的工作寄存器Rn中。有直接、立即和寄存器寻址方式: MOV Rn,data ;(data)→(Rn) 直接寻址单元中的内容送到寄存器Rn中 MOV Rn,#data ;#data→(Rn) 立即数直接送到寄存器Rn中 MOV Rn,A ;(A)→(Rn) 累加器A中的内容送到寄存器Rn中 [3]. 以直接地址为目的操作数的指令(5条) 这组指令的功能是把源操作数指定的内容送到由直接地址data所选定的片内RAM中。有直接、立即、寄存器和寄存器间接4种寻址方式: MOV data,data ;(data)→(data) 直接地址单元中的内容送到直接地址单元 MOV data,#data ;#data→(data) 立即数送到直接地址单元 MOV data,A ;(A)→(data) 累加器A中的内容送到直接地址单元 MOV data,Rn ;(Rn)→(data) 寄存器Rn中的内容送到直接地址单元 MOV data,@Ri ;((Ri))→(data) 寄存器Ri中的内容指定的地址单元中数据送到直接地址单元 [4]. 以间接地址为目的操作数的指令(3条) 这组指令的功能是把源操作数指定的内容送到以Ri中的内容为地址的片内RAM中。有直接、立即和寄存器3种寻址方式: MOV @Ri,data ;(data)→((Ri)) 直接地址单元中的内容送到以Ri中的内容为地址的RAM单元 MOV @Ri,#data ;#data→((Ri)) 立即数送到以Ri中的内容为地址的RAM单元 MOV @Ri,A ;(A)→((Ri)) 累加器A中的内容送到以Ri中的内容为地址的RAM单元 [5]. 查表指令(2条) 这组指令的功能是对存放于程序存储器中的数据表格进行查找传送,使用变址寻址方式: MOVC A,@A+DPTR ;((A))+(DPTR)→(A) 表格地址单元中的内容送到累加器A中 MOVC A,@A+PC ;((PC))+1→(A),((A))+(PC)→(A) 表格地址单元中的内容送到累加器A中 [6]. 累加器A与片外数据存储器RAM传送指令(4条) 这4条指令的作用是累加器A与片外RAM间的数据传送。使用寄存器寻址方式: MOVX @DPTR,A ;(A)→((DPTR)) 累加器中的内容送到数据指针指向片外RAM地址中 MOVX A, @DPTR ;((DPTR))→(A) 数据指针指向片外RAM地址中的内容送到累加器A中 MOVX A, @Ri ;((Ri))→(A) 寄存器Ri指向片外RAM地址中的内容送到累加器A中 MOVX @Ri,A ;(A)→((Ri)) 累加器中的内容送到寄存器Ri指向片外RAM地址中 [7]. 堆栈操作类指令(2条) 这4类指令的作用是把直接寻址单元的内容传送到堆栈指针SP所指的单元中,以及把SP所指单元的内容送到直接寻址单元中。这类指令只有两条,下述的第一条常称为入栈操作指令,第二条称为出栈操作指令。需要指出的是,单片机开机复位后,(SP)默认为07H,但一般都需要重新赋值,设置新的SP首址。入栈的第一个数据必须存放于SP+1所指存储单元,故实际的堆栈底为SP+1所指的存储单元。 PUSH data ;(SP)+1→(SP),(data)→(SP) 堆栈指针首先加1,直接寻址单元中的数据送到堆栈指针SP所指的单元中 POP data ;(SP)→(data)(SP)-1→(SP), 堆栈指针SP所指的单元数据送到直接寻址单元中,堆栈指针SP再进行减1操作 [8]. 交换指令(5条) 这5条指令的功能是把累加器A中的内容与源操作数所指的数据相互交换。 XCH A,Rn ;(A)←→(Rn)累加器与工作寄存器Rn中的内容互换 XCH A,@Ri ;(A)←→((Ri))累加器与工作寄存器Ri所指的存储单元中的内容互换 XCH A,data ;(A)←→(data)累加器与直接地址单元中的内容互换 XCHD A,@Ri ;(A 3-0 )←→((Ri) 3-0 )累加器与工作寄存器Ri所指的存储单元中的内容低半字节互换 SWAP A ;(A 3-0 )←→(A 7-4 )累加器中的内容高低半字节互换 [9]. 16位数据传送指令(1条) 这条指令的功能是把16位常数送入数据指针寄存器。 MOV DPTR,#data16 ;#dataH→(DPH),#dataL→(DPL)16位常数的高8位送到DPH,低8位送到DPL MCS-51算术运算指令 算术运算指令共有24条,算术运算主要是执行加、减、乘、除法四则运算。另外MCS-51指令系统中有相当一部分是进行加、减1操作,BCD码的运算和调整,我们都归类为运算指令。虽然MCS-51单片机的算术逻辑单元ALU仅能对8位无符号整数进行运算,但利用进位标志C,则可进行多字节无符号整数的运算。同时利用溢出标志,还可以对带符号数进行补码运算。需要指出的是,除加、减1指令外,这类指令大多数都会对PSW(程序状态字)有影响。这在使用中应特别注意。 [1]. 加法指令(4条) 这4条指令的作用是把立即数,直接地址、工作寄存器及间接地址内容与累加器A的内容相加,运算结果存在A中。 ADD A,#data ;(A)+#data→(A) 累加器A中的内容与立即数#data相加,结果存在A中 ADD A,data ;(A)+(data)→(A) 累加器A中的内容与直接地址单元中的内容相加,结果存在A中 ADD A,Rn ;(A)+(Rn)→(A) 累加器A中的内容与工作寄存器Rn中的内容相加,结果存在A中 ADD A,@Ri ;(A)+((Ri))→(A) 累加器A中的内容与工作寄存器Ri所指向地址单元中的内容相加,结果存在A中 [2]. 带进位加法指令(4条) 这4条指令除与[1]功能相同外,在进行加法运算时还需考虑进位问题。 ADDC A,data ;(A)+(data)+(C)→(A) 累加器A中的内容与直接地址单元的内容连同进位位相加,结果存在A中 ADDC A,#data ;(A)+#data +(C)→(A) 累加器A中的内容与立即数连同进位位相加,结果存在A中 ADDC A,Rn ;(A)+Rn+(C)→(A) 累加器A中的内容与工作寄存器Rn中的内容、连同进位位相加,结果存在A中 ADDC A,@Ri ;(A)+((Ri))+(C)→(A) 累加器A中的内容与工作寄存器Ri指向地址单元中的内容、连同进位位相加,结果存在A中 [3]. 带借位减法指令(4条) 这组指令包含立即数、直接地址、间接地址及工作寄存器与累加器A连同借位位C内容相减,结果送回累加器A中。 这里我们对借位位C的状态作出说明,在进行减法运算中,CY=1表示有借位,CY=0则无借位。OV=1声明带符号数相减时,从一个正数减去一个负数结果为负数,或者从一个负数中减去一个正数结果为正数的错误情况。在进行减法运算前,如果不知道借位标志位C的状态,则应先对CY进行清零操作。 SUBB A,data ;(A)-(data) - (C)→(A) 累加器A中的内容与直接地址单元中的内容、连同借位位相减,结果存在A中 SUBB A,#data ;(A)-#data -(C)→(A) 累加器A中的内容与立即数、连同借位位相减,结果存在A中 SUBB A,Rn ;(A)-(Rn) -(C)→(A) 累加器A中的内容与工作寄存器中的内容、连同借位位相减,结果存在A中 SUBB A,@Ri ;(A)-((Ri)) -(C)→(A) 累加器A中的内容与工作寄存器Ri指向的地址单元中的内容、连同借位位相减,结果存在A中 [4]. 乘法指令(1条) 这个指令的作用是把累加器A和寄存器B中的8位无符号数相乘,所得到的是16位乘积,这个结果低8位存在累加器A,而高8位存在寄存器B中。如果OV=1,说明乘积大于FFH,否则OV=0,但进位标志位CY总是等于0。 MUL AB ;(A)×(B)→(A)和(B) 累加器A中的内容与寄存器B中的内容相乘,结果存在A、B中 [5]. 除法指令(1条) 这个指令的作用是把累加器A的8位无符号整数除以寄存器B中的8位无符号整数,所得到的商存在累加器A,而余数存在寄存器B中。除法运算总是使OV和进位标志位CY等于0。如果OV=1,表明寄存器B中的内容为00H,那么执行结果为不确定值,表示除法有溢出。 DIV AB ;(A)÷(B)→(A)和(B) 累加器A中的内容除以寄存器B中的内容,所得到的商存在累加器A,而余数存在寄存器B中。 [6]. 加1指令(5条) 这5条指令的的功能均为原寄存器的内容加1,结果送回原寄存器。上述提到,加1指令不会对任何标志有影响,如果原寄存器的内容为FFH,执行加1后,结果就会是00H。这组指令共有直接、寄存器、寄存器减间址等寻址方式: INC A ;(A)+1→(A) 累加器A中的内容加1,结果存在A中 INC data ;(data)+1→(data) 直接地址单元中的内容加1,结果送回原地址单元中 INC @Ri ;((Ri))+1→((Ri)) 寄存器的内容指向的地址单元中的内容加1,结果送回原地址单元中 INC Rn ;(Rn)+1→(Rn)寄存器Rn的内容加1,结果送回原地址单元中 INC DPTR ;(DPTR)+1→(DPTR)数据指针的内容加1,结果送回数据指针中 在INC data这条指令中,如果直接地址是I/O,其功能是先读入I/O锁存器的内容,然后在CPU进行加1操作,再输出到I/O上,这就是“读—修改—写”操作。 [7]. 减1指令(4条) 这组指令的作用是把所指的寄存器内容减1,结果送回原寄存器,若原寄存器的内容为00H,减1后即为FFH,运算结果不影响任何标志位,这组指令共有直接、寄存器、寄存器间址等寻址方式,当直接地址是I/O口锁存器时,“读—修改—写”操作与加1指令类似。 DEC A ;(A)-1→(A)累加器A中的内容减1,结果送回累加器A中 DEC data ;(data)-1→(data)直接地址单元中的内容减1,结果送回直接地址单元中 DEC @Ri ;((Ri))-1→((Ri))寄存器Ri指向的地址单元中的内容减1,结果送回原地址单元中 DEC Rn ;(Rn)-1→(Rn)寄存器Rn中的内容减1,结果送回寄存器Rn中 [8]. 十进制调整指令(1条) 在进行BCD码运算时,这条指令总是跟在ADD或ADDC指令之后,其功能是将执行加法运算后存于累加器A中的结果进行调整和修正。 DA A MCS-51逻辑运算及移位指令 逻辑运算和移位指令共有25条,有与、或、异或、求反、左右移位、清0等逻辑操作,有直接、寄存器和寄存器间址等寻址方式。这类指令一般不影响程序状态字(PSW)标志。 [1]. 循环移位指令(4条) 这4条指令的作用是将累加器中的内容循环左或右移一位,后两条指令是连同进位位CY一起移位。 RL A ;累加器A中的内容左移一位 RR A ;累加器A中的内容右移一位 RLC A ;累加器A中的内容连同进位位CY左移一位 RRC A ;累加器A中的内容连同进位位CY右移一位 [2]. 累加器半字节交换指令(1条) 这条指令是将累加器中的内容高低半字节互换,这在上一节中内容已有介绍。 SWAP A ; 累加器中的内容高低半字节互换 [3]. 求反指令(1条) 这条指令将累加器中的内容按位取反。 CPL A ; 累加器中的内容按位取反 [4]. 清零指令(1条) 这条指令将累加器中的内容清0。 CLR A ; 0→(A),累加器中的内容清0 [5]. 逻辑与操作指令(6条) 这组指令的作用是将两个单元中的内容执行逻辑与操作。如果直接地址是I/O地址,则为“读—修改—写”操作。 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条) 这组指令的作用是将两个单元中的内容执行逻辑异或操作。如果直接地址是I/O地址,则为“读—修改—写”操作。 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中。 MCS-51控制转移指令 控制转移指令用于控制程序的流向,所控制的范围即为程序存储器区间,MCS-51系列单片机的控制转移指令相对丰富,有可对64kB程序空间地址单元进行访问的长调用、长转移指令,也有可对2kB字节进行访问的绝对调用和绝对转移指令,还有在一页范围内短相对转移及其它无条件转移指令,这些指令的执行一般都不会对标志位有影响。 [1]. 无条件转移指令(4条) 这组指令执行完后,程序就会无条件转移到指令所指向的地址上去。长转移指令访问的程序存储器空间为16地址64kB,绝对转移指令访问的程序存储器空间为11位地址2kB空间。 LJMP addr16 ;addr16→(PC),给程序计数器赋予新值(16位地址) AJMP addr11 ;(PC)+2→(PC),addr11→(PC 10-0 )程序计数器赋予新值(11位地址),(PC 15-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指向地址单元中的内容不等于立即数,则转移到偏移量所指向的地址,否则程序往下执行 DJNZ Rn, rel ; (Rn)-1→(Rn),(Rn)≠0,(PC)+ 2 + rel→(PC)工作寄存器Rn减1不等于0,则转移到偏移量所指向的地址,否则程序往下执行 DJNZ data, rel ; (Rn)-1→(Rn),(Rn)≠0,(PC)+ 2 + rel→(PC)直接地址单元中的内容减1不等于0,则转移到偏移量所指向的地址,否则程序往下执行 [3]. 子程序调用指令(1条) 子程序是为了便于程序编写,减少那些需反复执行的程序占用多余的地址空间而引入的程序分支,从而有了主程序和子程序的概念,需要反复执行的一些程序,我们在编程时一般都把它们编写成子程序,当需要用它们时,就用一个调用命令使程序按调用的地址去执行,这就需要子程序的调用指令和返回指令。 LCALL addr16 ; 长调用指令,可在64kB空间调用子程序。此时(PC)+ 3→(PC),(SP)+ 1→(SP),(PC 7-0 )→(SP),(SP)+ 1→(SP),(PC 15-8 )→(SP),addr16→(PC),即分别从堆栈中弹出调用子程序时压入的返回地址 ACALL addr11 ; 绝对调用指令,可在2kB空间调用子程序,此时(PC)+ 2→(PC),(SP)+ 1→(SP),(PC 7-0 )→(SP),(SP)+ 1→(SP),(PC 15-8 )→(SP),addr11→(PC 10-0 ) RET ; 子程序返回指令。此时(SP)→(PC 15-8 ),(SP)- 1→(SP),(SP)→(PC 7-0 ),(SP)- 1→(SP) RETI ; 中断返回指令,除具有RET功能外,还具有恢复中断逻辑的功能,需注意的是,RETI指令不能用RET代替 [4]. 空操作指令(1条) 这条指令将累加器中的内容清0。 NOP ; 这条指令除了使PC加1,消耗一个机器周期外,没有执行任何操作。可用于短时间的延时 MCS-51布尔变量操作指令 布尔处理功能是MCS-51系列单片机的一个重要特征,这是出于实际应用需要而设置的。布尔变量也即开关变量,它是以位(bit)为单位进行操作的。 在物理结构上,MCS-51单片机有一个布尔处理机,它以进位标志做为累加位,以内部RAM可寻址的128个为存储位。 既然有布尔处理机功能,所以也就有相应的布尔操作指令集,下面我们分别谈论。 [1]. 位传送指令(2条) 位传送指令就是可寻址位与累加位CY之间的传送,指令有两条。 MOV C,bit ;bit→CY,某位数据送CY MOV bit,C ;CY→bit,CY数据送某位 [2]. 位置位复位指令(4条) 这些指令对CY及可寻址位进行置位或复位操作,共有四条指令。 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”。 后三条指令都是三字节指令,如果条件满足,(PC)+3+rel→PC,否则程序往下执行,(PC)+3→PC

7,80C51单片机指令系统共有多少条指令

80C51共有111条指令
有42个助记符,111条指令,指令分五大类:数据传送指令,算术运算指令,逻辑运算指令,程序控制指令,位操作指令。单字节指令49,双字节指令46,三字节指令16。
111条,一共分为四大类:数据传送类,数据处理类,位操作指令,程序控制指令 祝你开心

8,单片机1k的程序存储器能写多少条汇编语句

一条指令有单字节的 双字节的和三字节的,双字节的比较多 因此1k大约可以写500多条指令有些单片机的存储器字长是14位或者16位组成,并且所有指令都不超过14位或者16位这时1K的容量就可以写1000多条指令
如果用1k*8b的ram芯片组成8k*8b的存储器,需要8 个芯片, 每个芯片的地址线是10根,因2^10=1024=1k由于有8 个芯片,所以要有3根地址线作为芯片的片选控制, 2^3=83-8译码器可以担当这个角色

9,51单片机内部存储器能存多少条c语言的程序

汇编指令一条通常占1~3个字节,与你的具体指令有关,例如INC ACC占1字节、MOV A,30H占2字节、LJMP ××就得占3个字节。短程序对照指令表一个一个计算可知,长的通常估算就用2字节乘指令行数得个大概值。C语言,可以说编译出来的程序代码大小与写的行数几乎没有关系了,将C程序编译看反汇编就可知道,大小由反汇编出来的指令数决定。比方说C语言中开方运算a=squr(b);仅此一行就可汇编成近千条指令。这就是为什么常说的C语言不如汇编简洁的原因。至于51单片机存多少条指令还得看你用芯片的型号。51系列门类很多,初学者常用的ATMEL公司的AT89C51/AT89S51的程序存储区容量是4K字节的,AT89C52/AT89S52是8K的;若程序量较大且超过片内容量又不想片外扩容的话,可用WINBOND华邦公司的W78E54(16K)/W78E58(32K),华邦的片在市场上还是很好找的。更多电子问题请关注我!zhidao_ceo竭诚为您解答!
既不是c,也不是汇编,是符合单片机要求的一种目标代码格式。c和汇编仅仅是程序编写的一种途径。c相对容易学,但编译后的文件较大。汇编学起来难度大,但指令的表达相对简单,编译后的文件也小。但格式都是相同的。

10,MCS51系列单片机指令系统共有111条指令谁能具体的列出这111条

MCS-51数据传送指令 数据传送指令共有29条,数据传送指令一般的操作是把源操作数传送到目的操作数,指令执行完成后,源操作数不变,目的操作数等于源操作数。如果要求在进行数据传送时,目的操作数不丢失,则不能用直接传送指令,而采用交换型的数据传送指令,数据传送指令不影响标志C,AC和OV,但可能会对奇偶标志P有影响。 [1]. 以累加器A为目的操作数类指令(4条) 这4条指令的作用是把源操作数指向的内容送到累加器A。有直接、立即数、寄存器和寄存器间接寻址方式: MOV A,data ;(data)→(A) 直接单元地址中的内容送到累加器A MOV A,#data ;#data→(A) 立即数送到累加器A中 MOV A,Rn ;(Rn)→(A) Rn中的内容送到累加器A中 MOV A,@Ri ;((Ri))→(A) Ri内容指向的地址单元中的内容送到累加器A [2]. 以寄存器Rn为目的操作数的指令(3条) 这3条指令的功能是把源操作数指定的内容送到所选定的工作寄存器Rn中。有直接、立即和寄存器寻址方式: MOV Rn,data ;(data)→(Rn) 直接寻址单元中的内容送到寄存器Rn中 MOV Rn,#data ;#data→(Rn) 立即数直接送到寄存器Rn中 MOV Rn,A ;(A)→(Rn) 累加器A中的内容送到寄存器Rn中 [3]. 以直接地址为目的操作数的指令(5条) 这组指令的功能是把源操作数指定的内容送到由直接地址data所选定的片内RAM中。有直接、立即、寄存器和寄存器间接4种寻址方式: MOV data,data ;(data)→(data) 直接地址单元中的内容送到直接地址单元 MOV data,#data ;#data→(data) 立即数送到直接地址单元 MOV data,A ;(A)→(data) 累加器A中的内容送到直接地址单元 MOV data,Rn ;(Rn)→(data) 寄存器Rn中的内容送到直接地址单元 MOV data,@Ri ;((Ri))→(data) 寄存器Ri中的内容指定的地址单元中数据送到直接地址单元 [4]. 以间接地址为目的操作数的指令(3条) 这组指令的功能是把源操作数指定的内容送到以Ri中的内容为地址的片内RAM中。有直接、立即和寄存器3种寻址方式: MOV @Ri,data ;(data)→((Ri)) 直接地址单元中的内容送到以Ri中的内容为地址的RAM单元 MOV @Ri,#data ;#data→((Ri)) 立即数送到以Ri中的内容为地址的RAM单元 MOV @Ri,A ;(A)→((Ri)) 累加器A中的内容送到以Ri中的内容为地址的RAM单元 [5]. 查表指令(2条) 这组指令的功能是对存放于程序存储器中的数据表格进行查找传送,使用变址寻址方式: MOVC A,@A+DPTR ;((A))+(DPTR)→(A) 表格地址单元中的内容送到累加器A中 MOVC A,@A+PC ;((PC))+1→(A),((A))+(PC)→(A) 表格地址单元中的内容送到累加器A中 [6]. 累加器A与片外数据存储器RAM传送指令(4条) 这4条指令的作用是累加器A与片外RAM间的数据传送。使用寄存器寻址方式: MOVX @DPTR,A ;(A)→((DPTR)) 累加器中的内容送到数据指针指向片外RAM地址中 MOVX A, @DPTR ;((DPTR))→(A) 数据指针指向片外RAM地址中的内容送到累加器A中 MOVX A, @Ri ;((Ri))→(A) 寄存器Ri指向片外RAM地址中的内容送到累加器A中 MOVX @Ri,A ;(A)→((Ri)) 累加器中的内容送到寄存器Ri指向片外RAM地址中 [7]. 堆栈操作类指令(2条) 这4类指令的作用是把直接寻址单元的内容传送到堆栈指针SP所指的单元中,以及把SP所指单元的内容送到直接寻址单元中。这类指令只有两条,下述的第一条常称为入栈操作指令,第二条称为出栈操作指令。需要指出的是,单片机开机复位后,(SP)默认为07H,但一般都需要重新赋值,设置新的SP首址。入栈的第一个数据必须存放于SP+1所指存储单元,故实际的堆栈底为SP+1所指的存储单元。 PUSH data ;(SP)+1→(SP),(data)→(SP) 堆栈指针首先加1,直接寻址单元中的数据送到堆栈指针SP所指的单元中 POP data ;(SP)→(data)(SP)-1→(SP), 堆栈指针SP所指的单元数据送到直接寻址单元中,堆栈指针SP再进行减1操作 [8]. 交换指令(5条) 这5条指令的功能是把累加器A中的内容与源操作数所指的数据相互交换。 XCH A,Rn ;(A)←→(Rn)累加器与工作寄存器Rn中的内容互换 XCH A,@Ri ;(A)←→((Ri))累加器与工作寄存器Ri所指的存储单元中的内容互换 XCH A,data ;(A)←→(data)累加器与直接地址单元中的内容互换 XCHD A,@Ri ;(A 3-0 )←→((Ri) 3-0 )累加器与工作寄存器Ri所指的存储单元中的内容低半字节互换 SWAP A ;(A 3-0 )←→(A 7-4 )累加器中的内容高低半字节互换 [9]. 16位数据传送指令(1条) 这条指令的功能是把16位常数送入数据指针寄存器。 MOV DPTR,#data16 ;#dataH→(DPH),#dataL→(DPL)16位常数的高8位送到DPH,低8位送到DPL MCS-51算术运算指令 算术运算指令共有24条,算术运算主要是执行加、减、乘、除法四则运算。另外MCS-51指令系统中有相当一部分是进行加、减1操作,BCD码的运算和调整,我们都归类为运算指令。虽然MCS-51单片机的算术逻辑单元ALU仅能对8位无符号整数进行运算,但利用进位标志C,则可进行多字节无符号整数的运算。同时利用溢出标志,还可以对带符号数进行补码运算。需要指出的是,除加、减1指令外,这类指令大多数都会对PSW(程序状态字)有影响。这在使用中应特别注意。 [1]. 加法指令(4条) 这4条指令的作用是把立即数,直接地址、工作寄存器及间接地址内容与累加器A的内容相加,运算结果存在A中。 ADD A,#data ;(A)+#data→(A) 累加器A中的内容与立即数#data相加,结果存在A中 ADD A,data ;(A)+(data)→(A) 累加器A中的内容与直接地址单元中的内容相加,结果存在A中 ADD A,Rn ;(A)+(Rn)→(A) 累加器A中的内容与工作寄存器Rn中的内容相加,结果存在A中 ADD A,@Ri ;(A)+((Ri))→(A) 累加器A中的内容与工作寄存器Ri所指向地址单元中的内容相加,结果存在A中 [2]. 带进位加法指令(4条) 这4条指令除与[1]功能相同外,在进行加法运算时还需考虑进位问题。 ADDC A,data ;(A)+(data)+(C)→(A) 累加器A中的内容与直接地址单元的内容连同进位位相加,结果存在A中 ADDC A,#data ;(A)+#data +(C)→(A) 累加器A中的内容与立即数连同进位位相加,结果存在A中 ADDC A,Rn ;(A)+Rn+(C)→(A) 累加器A中的内容与工作寄存器Rn中的内容、连同进位位相加,结果存在A中 ADDC A,@Ri ;(A)+((Ri))+(C)→(A) 累加器A中的内容与工作寄存器Ri指向地址单元中的内容、连同进位位相加,结果存在A中 [3]. 带借位减法指令(4条) 这组指令包含立即数、直接地址、间接地址及工作寄存器与累加器A连同借位位C内容相减,结果送回累加器A中。 这里我们对借位位C的状态作出说明,在进行减法运算中,CY=1表示有借位,CY=0则无借位。OV=1声明带符号数相减时,从一个正数减去一个负数结果为负数,或者从一个负数中减去一个正数结果为正数的错误情况。在进行减法运算前,如果不知道借位标志位C的状态,则应先对CY进行清零操作。 SUBB A,data ;(A)-(data) - (C)→(A) 累加器A中的内容与直接地址单元中的内容、连同借位位相减,结果存在A中 SUBB A,#data ;(A)-#data -(C)→(A) 累加器A中的内容与立即数、连同借位位相减,结果存在A中 SUBB A,Rn ;(A)-(Rn) -(C)→(A) 累加器A中的内容与工作寄存器中的内容、连同借位位相减,结果存在A中 SUBB A,@Ri ;(A)-((Ri)) -(C)→(A) 累加器A中的内容与工作寄存器Ri指向的地址单元中的内容、连同借位位相减,结果存在A中 [4]. 乘法指令(1条) 这个指令的作用是把累加器A和寄存器B中的8位无符号数相乘,所得到的是16位乘积,这个结果低8位存在累加器A,而高8位存在寄存器B中。如果OV=1,说明乘积大于FFH,否则OV=0,但进位标志位CY总是等于0。 MUL AB ;(A)×(B)→(A)和(B) 累加器A中的内容与寄存器B中的内容相乘,结果存在A、B中 [5]. 除法指令(1条) 这个指令的作用是把累加器A的8位无符号整数除以寄存器B中的8位无符号整数,所得到的商存在累加器A,而余数存在寄存器B中。除法运算总是使OV和进位标志位CY等于0。如果OV=1,表明寄存器B中的内容为00H,那么执行结果为不确定值,表示除法有溢出。 DIV AB ;(A)÷(B)→(A)和(B) 累加器A中的内容除以寄存器B中的内容,所得到的商存在累加器A,而余数存在寄存器B中。 [6]. 加1指令(5条) 这5条指令的的功能均为原寄存器的内容加1,结果送回原寄存器。上述提到,加1指令不会对任何标志有影响,如果原寄存器的内容为FFH,执行加1后,结果就会是00H。这组指令共有直接、寄存器、寄存器减间址等寻址方式: INC A ;(A)+1→(A) 累加器A中的内容加1,结果存在A中 INC data ;(data)+1→(data) 直接地址单元中的内容加1,结果送回原地址单元中 INC @Ri ;((Ri))+1→((Ri)) 寄存器的内容指向的地址单元中的内容加1,结果送回原地址单元中 INC Rn ;(Rn)+1→(Rn)寄存器Rn的内容加1,结果送回原地址单元中 INC DPTR ;(DPTR)+1→(DPTR)数据指针的内容加1,结果送回数据指针中 在INC data这条指令中,如果直接地址是I/O,其功能是先读入I/O锁存器的内容,然后在CPU进行加1操作,再输出到I/O上,这就是“读—修改—写”操作。 [7]. 减1指令(4条) 这组指令的作用是把所指的寄存器内容减1,结果送回原寄存器,若原寄存器的内容为00H,减1后即为FFH,运算结果不影响任何标志位,这组指令共有直接、寄存器、寄存器间址等寻址方式,当直接地址是I/O口锁存器时,“读—修改—写”操作与加1指令类似。 DEC A ;(A)-1→(A)累加器A中的内容减1,结果送回累加器A中 DEC data ;(data)-1→(data)直接地址单元中的内容减1,结果送回直接地址单元中 DEC @Ri ;((Ri))-1→((Ri))寄存器Ri指向的地址单元中的内容减1,结果送回原地址单元中 DEC Rn ;(Rn)-1→(Rn)寄存器Rn中的内容减1,结果送回寄存器Rn中 [8]. 十进制调整指令(1条) 在进行BCD码运算时,这条指令总是跟在ADD或ADDC指令之后,其功能是将执行加法运算后存于累加器A中的结果进行调整和修正。 DA A MCS-51逻辑运算及移位指令 逻辑运算和移位指令共有25条,有与、或、异或、求反、左右移位、清0等逻辑操作,有直接、寄存器和寄存器间址等寻址方式。这类指令一般不影响程序状态字(PSW)标志。 [1]. 循环移位指令(4条) 这4条指令的作用是将累加器中的内容循环左或右移一位,后两条指令是连同进位位CY一起移位。 RL A ;累加器A中的内容左移一位 RR A ;累加器A中的内容右移一位 RLC A ;累加器A中的内容连同进位位CY左移一位 RRC A ;累加器A中的内容连同进位位CY右移一位 [2]. 累加器半字节交换指令(1条) 这条指令是将累加器中的内容高低半字节互换,这在上一节中内容已有介绍。 SWAP A ; 累加器中的内容高低半字节互换 [3]. 求反指令(1条) 这条指令将累加器中的内容按位取反。 CPL A ; 累加器中的内容按位取反 [4]. 清零指令(1条) 这条指令将累加器中的内容清0。 CLR A ; 0→(A),累加器中的内容清0 [5]. 逻辑与操作指令(6条) 这组指令的作用是将两个单元中的内容执行逻辑与操作。如果直接地址是I/O地址,则为“读—修改—写”操作。 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条) 这组指令的作用是将两个单元中的内容执行逻辑异或操作。如果直接地址是I/O地址,则为“读—修改—写”操作。 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中。 MCS-51控制转移指令 控制转移指令用于控制程序的流向,所控制的范围即为程序存储器区间,MCS-51系列单片机的控制转移指令相对丰富,有可对64kB程序空间地址单元进行访问的长调用、长转移指令,也有可对2kB字节进行访问的绝对调用和绝对转移指令,还有在一页范围内短相对转移及其它无条件转移指令,这些指令的执行一般都不会对标志位有影响。 [1]. 无条件转移指令(4条) 这组指令执行完后,程序就会无条件转移到指令所指向的地址上去。长转移指令访问的程序存储器空间为16地址64kB,绝对转移指令访问的程序存储器空间为11位地址2kB空间。 LJMP addr16 ;addr16→(PC),给程序计数器赋予新值(16位地址) AJMP addr11 ;(PC)+2→(PC),addr11→(PC 10-0 )程序计数器赋予新值(11位地址),(PC 15-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指向地址单元中的内容不等于立即数,则转移到偏移量所指向的地址,否则程序往下执行 DJNZ Rn, rel ; (Rn)-1→(Rn),(Rn)≠0,(PC)+ 2 + rel→(PC)工作寄存器Rn减1不等于0,则转移到偏移量所指向的地址,否则程序往下执行 DJNZ data, rel ; (Rn)-1→(Rn),(Rn)≠0,(PC)+ 2 + rel→(PC)直接地址单元中的内容减1不等于0,则转移到偏移量所指向的地址,否则程序往下执行 [3]. 子程序调用指令(1条) 子程序是为了便于程序编写,减少那些需反复执行的程序占用多余的地址空间而引入的程序分支,从而有了主程序和子程序的概念,需要反复执行的一些程序,我们在编程时一般都把它们编写成子程序,当需要用它们时,就用一个调用命令使程序按调用的地址去执行,这就需要子程序的调用指令和返回指令。 LCALL addr16 ; 长调用指令,可在64kB空间调用子程序。此时(PC)+ 3→(PC),(SP)+ 1→(SP),(PC 7-0 )→(SP),(SP)+ 1→(SP),(PC 15-8 )→(SP),addr16→(PC),即分别从堆栈中弹出调用子程序时压入的返回地址 ACALL addr11 ; 绝对调用指令,可在2kB空间调用子程序,此时(PC)+ 2→(PC),(SP)+ 1→(SP),(PC 7-0 )→(SP),(SP)+ 1→(SP),(PC 15-8 )→(SP),addr11→(PC 10-0 ) RET ; 子程序返回指令。此时(SP)→(PC 15-8 ),(SP)- 1→(SP),(SP)→(PC 7-0 ),(SP)- 1→(SP) RETI ; 中断返回指令,除具有RET功能外,还具有恢复中断逻辑的功能,需注意的是,RETI指令不能用RET代替 [4]. 空操作指令(1条) 这条指令将累加器中的内容清0。 NOP ; 这条指令除了使PC加1,消耗一个机器周期外,没有执行任何操作。可用于短时间的延时 MCS-51布尔变量操作指令 布尔处理功能是MCS-51系列单片机的一个重要特征,这是出于实际应用需要而设置的。布尔变量也即开关变量,它是以位(bit)为单位进行操作的。 在物理结构上,MCS-51单片机有一个布尔处理机,它以进位标志做为累加位,以内部RAM可寻址的128个为存储位。 既然有布尔处理机功能,所以也就有相应的布尔操作指令集,下面我们分别谈论。 [1]. 位传送指令(2条) 位传送指令就是可寻址位与累加位CY之间的传送,指令有两条。 MOV C,bit ;bit→CY,某位数据送CY MOV bit,C ;CY→bit,CY数据送某位 [2]. 位置位复位指令(4条) 这些指令对CY及可寻址位进行置位或复位操作,共有四条指令。 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”。 后三条指令都是三字节指令,如果条件满足,(PC)+3+rel→PC,否则程序往下执行,(PC)+3→PC
文章TAG:51单片机有多少条语句单片机多少语句

最近更新

  • 无线键盘接口电路,电脑键盘按键不行怎么办?无线键盘接口电路,电脑键盘按键不行怎么办?

    接口电路。检查键盘和电脑主机之间的连接接口,以确定接触是否良好,再次插拔连接键盘和电脑主机的USB电缆,键盘电路板是整个键盘的控制核心,位于键盘内部,主要作为按键扫描识别、编码和传输.....

    半导体 日期:2024-04-11

  • 大功率灯泡功率多少,一般家用电灯泡功率多大大功率灯泡功率多少,一般家用电灯泡功率多大

    本文目录一览1,一般家用电灯泡功率多大2,平时所说的大功率LED灯是多大功率3,灯泡电功率一般是多少4,一个普通白炽灯泡功率为多少啊5,400W250W70W150W60W的电灯的功率是多大6,灯泡的实际功率.....

    半导体 日期:2024-04-10

  • 1节1号标准干电池的内阻计算多少,1号电池的内阻是多少1节1号标准干电池的内阻计算多少,1号电池的内阻是多少

    1号电池的内阻是多少2,一节干电池的内阻是多少3,1号和5号干电池内阻各多大4,干电池的内阻一般为多大5,一节干电池的电流是多大6,15V1号干电池内阻一般是多少7,1号电池内阻大约为多少8,一号干.....

    半导体 日期:2024-04-10

  • 运放水位控制电路,水泵水位控制电路示意图运放水位控制电路,水泵水位控制电路示意图

    家用水泵的自动抽水控制电路如下图所示:当水位下降时,浮子开关的触点闭合,水泵工作。电子水位开关和控制器,适用于污水环境,当水位下降到B点以下时,由于脚②的低电位而设置,高输出电平释放继.....

    半导体 日期:2024-04-10

  • 30mw是多少w,喇叭功率30MW 是 什么意思30mw是多少w,喇叭功率30MW 是 什么意思

    喇叭功率30MW是什么意思mW是表示功率大小的一种单位,1KW=1000W,1W=1000mW。2,30mwcm2等于多少wm230/1000*10000=300没看懂什么意思?3,2030mw什么意思20-30兆瓦,1兆瓦=1000KW虽然我很聪明,但这.....

    半导体 日期:2024-04-10

  • 下雨传感器电路,用于感应雨水的传感器下雨传感器电路,用于感应雨水的传感器

    雨雪传感器,雨雪天主机自动停机。当刮水器杆设置在INT位置时,下雨时,雨量传感器将自动感应雨量以挂水,它装有雨水传感器,刮风下雨时会自动关窗,GloriasaltyRV有一个雨水传感器,此时在外面晾晒.....

    半导体 日期:2024-04-10

  • 反 型滤波电路,反向过滤方法反 型滤波电路,反向过滤方法

    如果我们想要获得更好的滤波效果,通常需要一个由电容和电感组成的滤波电路,例如“π滤波电路”。通常π型滤波电路由两个电容和一个电阻组成,滤波效果较好,因为滤波电路需要大容量的储能电.....

    半导体 日期:2024-04-10

  • 有源回馈整流电压提升,反馈整流器和有源整流器的区别有源回馈整流电压提升,反馈整流器和有源整流器的区别

    使用电流源作为共发射极放大器电路的有源负载可以通过电流源的大交流等效电阻提高输出电压增益。单相桥式整流电路、双绕组全波整流电路和半波整流电路,整流后的电压为空载时的交流电压.....

    半导体 日期:2024-04-10