MCS-51系列单片机的存储器可划分为几个空间,地址范围以及容量是多少?

你真执着!一个是哈佛结构,一个是冯.诺依曼结构,即指令和数据存储的处理方式不一样。通俗一点讲,mcs51的所有指令和数据都存储在内置的flash里面,执行机构从flash里面读取指令和数据,译码、执行;而8086系列的cpu指令数据需要放置在内存中,换言之8086cpu不能像单片机一样,需要依赖外部非易失存储器和ram才可以工作。8086出现的早一些,当然,作为通用处理器的8086较之51功能也更强大。

片内数据存储器,51 系列是:00~FFH,共 256B。

mcs-51单片机 mcs-51单片机有几个优先级mcs-51单片机 mcs-51单片机有几个优先级


mcs-51单片机 mcs-51单片机有几个优先级


mcs-51单片机 mcs-51单片机有几个优先级


52 系列是:00~7FH,共 12看手册的呀8B。

片外数据存储器:0000~FFFFH,共 64KB。

特殊功能寄存器:80H~FFH,只有 21ORL C,/bit ;(CY)∧( )→CY 个单元。

位寻址区,RAM 功能:00~7FH,共 128 bit 。

MCS-51单片机的 P3口具有哪些功能?

除了可以作为一般的IO口之外其他的复用功能如下

P3.0 RXD 串行输入口

P3.1 TXD 串行输出口

P3.2 INT0 外部中断0输入口

P3.3 INT1 外部中断1输入4、控制转移指令口

P3.4 T0 定时器/计数器0外部ORL C,bit ;(CY)∨(bit)→CY时间脉冲输入端

P3.5 T1 定时器/计数器1外部时间脉冲输入端

[6]. 逻辑或作指令(6条)P3.6 WR 外部数据存储器写脉冲

P3.7 RD 外部数据存储器读脉冲

MCS-51系列单片机的中断系统分为几个优先级?如何设定?

这些指令对CY及可寻址位进行置位或复位作,共有四条指令。

MCS-51单片机有两个中断优先级。

[4]. 位控制转移指令(5)

在51单片机中,有2个可编程定时/计数器·5个中断源,2个优先级,21个专用寄存器。另有8位CPU的4kbytes程序存储器(ROM) ,128bytes的数据存储器(RAM),32条I/O口线·111条指令,大部分为单字节指令。

MOVX @Ri,A ;(A)→((Ri)) 累加器中的内容送到寄存器Ri指向片外RAM地址中

优先级设定方法:

3、同一优先级的中断优先权排队,由中断系统硬件确定的自然优先级形成,其排列从高到低为外部中断0;定时/计数器0;外部中断1;定时/计数器1;串行口。

4、每个中断源的中断优先级都是由中断优先级寄存器(IP)中的相应位的状态来规定的。

扩展资料:

其他性能结构一样,有片内128B RAM,2个16位定时器/计数器,5个中断源。其中,8031性价比较高,又易于开发,目前应用面广泛。

MCS-51采用超大规模集成电路技术把具有数据处理能力的处理器CPU随机存储器RAM、只读存储器ROM、多种I/O口和中断系统、定时器/计时器等功能集成到一块硅片上构成的一个小而完善的计算机系统。

参考资料来源:

单片机MCS-51汇编语言中的“A、B、C”指的是什么?

这组指令执行完后,程序就会无条件转移到指令所指向的地址上去。长转移指令访问的程序存储器空间为16地址64kB,转移指令访问的程序存储器空间为11位地址2kB空间。

它们的含义分别为:A是累加器,是使用频率的特殊寄存器。B是通用寄存器,也是可以参与乘、除运算指令的寄存器。C是进位位,属于位存储器,也是布尔处理机进行位运算常用的位寄存器,同时受某些算术、逻辑运算指令影响,表征结果的状态。

MCS-51单片机-伪指令

单片机是指一个集成在一块芯片上的完整计算机系统。

单片机是一种集成电路芯片,是采用超大规模集成电路技术把具有数据处理能力的处理器CPU、随机存储器RAM、只读存储器ROM、多种I/O口和中断系统、定时器/计数器等功能(可能还包括显示驱动电路、脉宽调制电路、模拟多路转换器、A/D转换器等电路)集成到一块硅片上构成的一个小而完善的计算机系统,在工业控制8031,片内含有:128B 的 RAM,无 ROM。领域广泛应用。

什么是51系列单片机

MCS-5151系列是基本型,包括8051、8751、8031、8951.这四个机种区别,仅在于片内程序储存器。8051为4KBROM,8751为4KBEPROM,8031片内无程序储存器,8951为4KBEEPROM。数据传送指令

51单片机是对目前所有兼容In 8031指令系统的单片机的统称。该系列单片机的始祖是In的8031单片机,

MCS-51控制转移指令

后来随着Flash rom技术的发展,8031单片机取得了长足的进展,成为目前应用广泛的8位单片机之一,其代表型号是ATMEL公司的AT89系列,它广泛应用于工业测控系统之中。目前很多公司都有51系列的兼容机型推出,在目前乃至今后很长的一段时间内将占有大量市场。51单片机即是基础入门的一个单片机,还是应用广泛的一种。需要注意的是52系列的单片机一般不具备自编程能力。 当前常用的51系列单片机主要产品有: In的:80C31、80C51、87C51,80C32、80C52、87C52等; ATMEL的:89C51、89C52、89C2051等; Philips、华邦、Dallas、Siemens(Infineon)等公司的许多产品。

51系列单片机指以51为内核的单片机

有一个STC51

MCS51是指由美国INTEL公司(对了,就是大名鼎鼎的INTEL)生产的一系列单片机的总称,这一系列单片机包括了好些品种,如8031,8051,8751,8032,8052,8752等,其中8051是早典型的产品,该系列其它单片机都是在8051的基础上进行功能的增、减、改变而来的,所以人们习惯于用8051来称呼MCS51系列单片机,而8031是前些年在我国的单片机,所以很多场合会看到8031的名称。

51核是一种处理器的内部结构、指令处理方式,使用了该结构的处理器都可以叫51系列单片机

MCS-51系列单片机中用于中断允许和中断优先级控制的寄存器分别是什么?

编程电压(25v):31脚(ea/vpp)

中断允许:IEx0dx0aEA(IE.7这条指令的功能是把16位常数送入数据指针寄存器。):总允许位x0dx0a(IE.6:保留)x0dx0aET2(IE.5):定时器2中断允许位(只适用于8052及其增强型)x0dx0aES(IE.4):串行中断允许位x0dx0aET1(IE.3):定时器1中断允许位x0dx0aEX1(IE.2):外部中断1允许位x0dx0aET0(IE.1):定时器0中断允许位x0dx0aEX0(IE.0):外部中断0允许位x0dx0ax0dx0a中断优先级:IPx0dx0a(IP.7:保留)x0dx0a(IP.6:保留)x0dxMOV bit,C ;CY→bit,CY数据送某位0aPT2(IP.5):若=1,定时器2中断设为高优先级(只适用于8052及其增强型)x0dx0aPS(IP.4):若=1,串行中断设为高优先级x0dx0aPT1(IP.3):若=1,定时器1中断设为高优先级x0dx0aPX1(IP.2):若=1,外部中断1设为高优先级x0dx0aPT0(IP.1):若=1,定时器0中断设为高优先级x0dx0aPX0(IP.0):若=1,外部中断0设为高优先级

试比较8088/8086CPU与MCS-51单片机不同之处

布尔处理功能是MCS-51系列单片机的一个重要特征,这是出于实际应用需要而设置的CPL A ; 累加器中的内容按位取反。布尔DA A变量也即开关变量,它是以位(bit)为单位进行作的。

MCS-51系列单片机指令系统共有111条指令,谁能具体的列出这111条指令?

INC @Ri ;((Ri))+1→((Ri)) 寄存器的内容指向的地址单元中的内容加1,结果送回原地址单元中

数据传送指令共有29条,数据传送指令一般的作是把源作数传送到目的作数,指令执行完成后,源作数不变,目的作数等于源作数。如果要求在进行数据传送时,目的作数不丢失,则不能用直接传送指令,而采用交换型的数据传送指令,数据传送指令不影响标志C,AC和OV,但可能会对奇偶标志P有影响。

[1]. 以累加器A为目的作数类指令(4条)

MOV A,data ;(data)→(A) 直接单元地址中的内容送到累加器A

MOV A,#data ;#data→(A) 立即数送到累加器这4条指令的作用是把立即数,直接地址、工作寄存器及间接地址内容与累加器A的内容相加,运算结果存在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中的内容指定的地址单元中数据送到直接地址单元

这组指令的功能是把源作数指定的内容送到以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中

[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条)

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条)

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条)

INC A ;(A)+1→(A) 累加器A中的内容加1,结果存在A中

INC Rn ;(Rn)+1→(Rn)寄存器Rn的内容加1,结果送回原地址单元中

[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中的结果进行调整和修正。

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 ; 累加器中的内容高低半字节互换

这条指令将累加器中的内容按位取反。

这条指令将累加器中的内容清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中。

这组指令的作用是将两个单元中的内容执行逻辑或作。如果直接地址是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 A,@Ri ;累加器A的内容和工作寄存器Ri指向的地址单元中的内容执行逻辑异或作。结果存在累加器A中。

[1]. 无条件转移指令(4条)

LJMP addr16 ;addr16→(PC),给程序计数器赋予新值(16位地址)

SJMP rel ;(PC)+ 2 + rel→(PC)当前程序计数器先加上2再加上偏移量给程序计数器赋予新值

JMP @A+DPTR ;(A)+ (DPTR)→(PC),累加器所指向地址单元的值加上数据指针的值给程序计数器赋予新值

程序可利用这组丰富的指令根据当前的条件进行判断,看是否满足某种特定的条件,从而控制程序的转向。

JZ rel ; A=0,(PC)+ 2 + rel→(PC),累加器中MCS-51布尔变量作指令的内容为0,则转移到偏移量所指向的地址,否则程序往下执行

JNZ rel ; A≠0,(PC)+ 2 + rel→(PC),累加器中的内容不为0,则转移到偏移量所指向的地址,否则程序往下执行

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单片机有一个布尔处理机,它以进位标志做为累加位,以内部RAM可寻址的128个为存储位。

既然有布尔处理机功能,所以也就有相应的布尔作指令集,下面我们分别谈论。

[1]. 位传送指令(2条)

位传送指令就是可寻址位与累加位CY之间的传送,指令有两条。

MOV C,bit ;bit→CY,某位数据送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

CPL C ;( )→CY

CPL bit ;( )→bir

位控制转移指令是以位的状态作为实现程序转移的判断条件,介绍如下:

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转移。

JBC bit, rel ; 位状态为1转移,并使该位清“0”。

后三条指令都是三字节指令,如果条件满足,(PC)+3+rel→PC,否则程序往下执行,(PC)+3→PC

MCS—51单片机的引脚EA的作用

ANL C,/bit ;(CY)∧( )→CY

EA引脚的作用,直接影响到单片机程序内部还是外部程序存储器执行,EA = 0低电平动作,也就是说当此引脚接低电平后,系统会取用外部的程序代码(存于外部EPROM中)来执行程序,51单片机,EA一般都是接VCC的。

(1)具有常驻的或变化缓慢的数据信号的外这4条指令的作用是把源作数指向的内容送到累加器A。有直接、立即数、寄存器和寄存器间接寻址方式:部设备.例如:机械开关,指示灯,发光二极管,数码管等.可以认为它们随时为输入输出数据处于"准备好"状态.