单片机原理及接口技术课后答案第三版.docx
单片机原理及接口技术课后答案(第三版)第一章1 .单片机具有哪些特点(1)片内存储容量越来越大。(2抗干扰性好,可靠性高。(3)芯片引线齐全,容易扩展。(4)运营速度高,控制功能强。(5)单片机内部的数据信息保存时间很长,有的芯片可以达成12023以上。2 .89C51单片机内包含哪些重要逻辑功能部件?答:80C51系列单片机在片内集成了以下重要逻辑功能部件:(I)CPU(中央解决器):8位(2)片内RAM:128B(3)特殊功能寄存器:21个(4)程序存储器:4KB(5)并行I/O口:8位,4个(6)串行接口:全双工,1个(7)定期器/计数器:16位,2个(8)片内时钟电路:1个3 .什么是微解决器(CPU)、微机和单片机?答:微解决器自身不是计算机,但它是小型计算机或微机的控制和解决部分。微机则是具有完整运算及控制功能的计算机,除了微解决器外还涉及存储器、接口适配器以及输入输出设备等。单片机是将微解决器、一定容量的RAM、ROM以及I/O口、定期器等电路集成在一块芯片上,构成的单片微型计算机。4 .微型计算机如何执行一个程序?答:通过CPU指令,提到内存当中,再逐个执行。5 .什么是嵌入式系统?他有哪些类型?为什么说单片机是典型的嵌入式系统?答;嵌入式系统是将先进的计算机技术、半导体技术和电子技术和各个行业的具体应用相结合后的产物,这一点就决定了它必然是一个技术密集、资金密集、高度分散、不断创新的知识集成系统。它有嵌入式微解决器、嵌入式微控制器、嵌入式DSP解决器、嵌入式片上系统等。嵌入式系统的出现最初是基于单片机的。它从体系结构到指令系统都是按照嵌入式应用特点专门设计的,能最佳的满足面对控制对象,应运系统的嵌入、现场的可靠运营以及非凡的控制品质规定。因此,她是典型的嵌入式系统。第二章1.89C51单片机内包含哪些重要逻辑功能部件?答:80C51系列单片机在片内集成了以下重要逻辑功能部件:(I)CPU(中央解决器):8位(2)片内RAM:128B(3)特殊功能寄存器:21个(4)程序存储器:4KB(5)并行I/O口:8位,4个(6)串行接口:全双工,1个定期器/计数器:16位,2个片内时钟电路:1个2 .89C51的EA端有何用途?答:/EA端接高电平时,CPU只访问片内并执行内部程序,存储器。/EA端接低电平时,CPU只访问外部ROM,并执行片外程序存储器中的指令。/EA端保持高电平时,CPU执行内部存储器中的指令。3 .89051的存储器分哪几个空间?如何区别不同空间的寻址?答:ROM(片内ROM和片外RoM统一编址)(使用MoVC)(数据传送指令)(16bits地址)(64KB)片外RAM(MOVX)(16bits地址)(64KB)片内RAM(MOV)(8bits地址)(256B)4 .简述89C51片内RAM的空间分派。答:片内RAM有256B低128B是真正的RAM区高128B是SFR(特殊功能寄存器)区5 .简述布尔解决存储器的空间分派,片内RAM中包含哪些可位寻址单元。答:片内RAM区从OOHFFH(256B)其中20H2FH(字节地址)是位寻址区相应的位地址是OoH7FH6 .如何简捷地判断89C51正在工作?答:用示波器观测8051的XTA1.2端是否有脉冲信号输出(判断震荡电路工作是否正常?)A1.E(地址锁存允许)(Address1.atchEnable)输出是fosc的6分须用示波器观测A1.E是否有脉冲输出(判断8051芯片的好坏?)观测PSEN(判断8051可以到EPROM或ROM中读取指令码?)由于/PSEN接外部EPRoM(ROM)的/0E端子OE=OutputEnable(输出允许)7 .89C51如何拟定和改变当前工作寄存器组?答:PSW(程序状态字)(ProgramStatusWord)中的RSl和RSO可以给出4中组合用来从4组工作寄存器组中进行选择PSW属于SFR(SpecialFunctionRegister)(特殊功能寄存器)8 .89C51PO口用作通用I/O口输入时,若通过TT1.“0C”门输入数据,应注意什么?为什么?答:9 .读端口锁存器和“读引脚”有何不同?各使用哪种指令?答:读锁存器(AN1.PO,A)就是相称于从存储器中拿数据,而读引脚是从外部拿数据(如MOVA,P1这条指令就是读引脚的,意思就是把端口Pl输入数据送给A)传送类MOV,判位转移JB、JNB.这些都属于读引脚,平时实验时经常用这些指令于外部通信,判断外部键盘等;字节互换XCH、XCHD算术及逻辑运算OR1.、CP1.、AN1.、ADD、ADD0、SUBB>INC、DEC控制转移CJNE、DJNZ都属于读锁存器。10.89C51POP3口结构有何不同?用作通用I/O口输入数据时,应注意什么?答:PO口内部没有上拉电阻,可以用做16位地址的低8位;P3有第二功能;P2口可以用做16位地址的高8位;需要上拉电阻。OC门电路无法输出高低电平,只有靠上拉电阻才干实现11 .89C51单片机的EA信号有何功能?在使用8031时,EA信号引脚应如何解决?答:(1)80C51单片机的EA信号的功能EA为片外程序存储器访问允许信号,低电平有效;在编程时,其上施加21V的编程电压EA引脚接高电平时,程序从片内程序存储器开始执行,即访问片内存储器;EA引脚接低电平时,迫使系统所有执行片外程序存储器程序。(2)在使用80C31时,EA信号引脚的解决方法由于80C31没有片内的程序存储器,所以在使用它时必然要有外部的程序存储器,EA信号引脚应接低电平。12 .89C51单片机有哪些信号需要芯片引脚以第2功能的方式提供?答:第一功能P3.0P3.1P3.2P3.3P3.4P3.5第二功能串行口:RXD(串行输入口)TXD(串行输出口)中断:INTO外部中断0INT1外部中断1定期器/计数器(TO、TD:T0(定期器/计数器0的外部输入)T1(定期器/计数器1的外部输入)数据存储器选通:P3.6WR(外部存储器写选通,低电平有效,输出)P3.7RD(外部存储器读选通,低电平有效,输出)定期器/计数器(T2):P1.0T2(定期器T2的计数端)P1.1T2EX(定期器T2的外部输入端)13 .内部RAM低128字节单元划分为哪3个重要部分?各部分重要功能是什么?答:片内RAM低128单元的划分及重要功能:(I)工作寄存器组(OOHIFH)这是一个用寄存器直接寻址的区域,内部数据RAM区的031(OOHlFH),共32个单元。它是4个通用工作寄存器组,每个组包含8个8位寄存器,编号为R(TR7。(2)位寻址区(20H2FH)从内部数据RAM区的3247(20H2FH)的16个字节单元,共包含128位,是可位寻址的RAM区。这16个字节单元,既可进行字节寻址,又可实现位寻址。(3)字节寻址区(30H7FH)从内部数据RAM区的48127(30H7FH),共80个字节单元,可以采用间接字节寻址的方法访问。14 .使单片机复位有几种方法?复位后机器的初始状态如何?答:(1)单片机复位方法单片机复位方法有:上电自动复位、按键电平复位和外部脉冲三种方式,如题图27所示。题图2-1(2)复位后的初始状态复位后机器的初始状态,即各寄存器的状态:PC之外,复位操作还对其他一些特殊功能寄存器有影响,它们的复位状态如题表2T所例15 .开机复位后,CPU使用的是哪组工作寄存器?它们的地址是什么?CPU如何拟定和改变当前工作寄存器组?答:一般开机复位后都是选择第一组通用工作寄存器作为工作寄存器的,一共有4组,分别为0.1.2.3连续位于Ooh到IFH地址,然后在机器中有个程序状态字PSW,它的第四和第三位RS1,RSO是用来选择工作寄存器组的,也许不同机器地址稍有不同。他们俩的值和寄存器组的关系:RS1/RS00/00/11/01/1使用的工作寄存器0123地址OO-O708-0F10-1718-1F写程序的时候就是通过定义程序状态字来选择使用不同的寄存器组。也可以直接对RS1和RSO赋值。(最后一问同题7)16 .程序状态寄存器PSW的作用是什么?常用标志有哪些位?作用是什么?答:PSW是一个SFR(特殊功能寄存器)位于片内RAM的高128B具体地址DOH(OOH-FFH)(片内RAM的编址)(8bits编址方法)PSW=ProgramStatusWord(程序状态字)PSW的常用标志位有哪些?CY=Carry(进位标志位)AC=AuxiIiaryCarry(辅助进位标志位)(半进位标志位)FO用户标志位RS1,RSO,用来选择当前工作寄存器组(R(TR7)(4选1)OV=OverfIow(溢出标志位)P=Parity(奇偶校验位)17 .位地址7CH与字节地址7CH如何区别?位地址7CH具体在片内RAM中的什么位置?答:用不同的寻址方式来加以区分,即访问128个位地址用位寻址方式,访问低128字节单元用字节寻址和间接寻址。具体地址为2F的第五位,即为7Co18 .89051单片机的时钟周期与振荡周期之间有什么关系?什么叫机器周期和指令周期?答:时钟信号的周期称为机器状态周期,是振荡周期的两倍。一个机器周期是指CPU访问存储器一次所需的时间。指令周期是执行一条指令所需的时间。19 .一个机器周期的时序如何划分?答:一个机器周期=12个震荡周期二6个时钟周期(状态周期)S1P1,S1P2,S2P1,S2P2,S3P1,S3P2,S4P1,S4P2,S5P1,S5P2,S6P1,S6P2其中s=state(状态),p=phase(相位)20 .什么叫堆栈?堆栈指针SP的作用是什么?89C51单片机堆栈的容量不能趣过多少字节?答:堆栈都是一种数据项按序排列的数据结构,只能在一端(称为栈顶(top)对数据项进行插入和删除。要点:堆:顺序随意栈:后进先出(1.aStTn/First-Out)在调用子程序时需要保存调用函数的CPU寄存器PC指针,PC指针是被CA1.1.指令自动压入SP所指向的片内存储器,CPU寄存器要由用户用PUSH指令自行保存,因此SP的作用就是一个指针,当进行中断调用,子函数调用时将现场数据压入SP所指向的存储器,SP自动增长1或2,当中断结束RETl,调用返回RET,POP时将SP数据弹出,SP自动减1或,28051最大为128字节的片内存储器,0X20以上理论都可以做堆栈用96字节,8052为256字节224字节可用,但这样便没有其它空间可用于数据存储现在的单片机的程序一般都能用C51来,不用关心堆栈大小与SP寄存器21 89C51有几种低功耗方式?如何实现?答:空闲方式和掉电方式空闲方式和掉电方式是通过对SFR中的PCON(地址87H)相应位置1而启动的。当CPU执行完置ID1.=I(PCON.1)的指令后,系统进入空闲工作方式。这时,内部时钟不向CPU提供,而只供应中断、串行口、定期器部分。CPU的内部状态维持,即涉及堆栈指针SP、程序计数器PC、程序状态字PSW、累加器ACC所有的内容保持不变,端口状态也保持不变。A1.E和PSEN保持逻辑高电平。当CPU执行一条置PCON.1位(PD)为1的指令后,系统进入掉电工作方式。在这种工作方式下,内部振荡器停止工作。由于没有振荡时钟,因此,所有的功能部件都停止工作。但内部RAM区和特殊功能寄存器的内容被保存,而端口的输出状态值都保存在相应的SFR中,A1.E和PSEN都为低电平。22 .PC与DPTR各有哪些特点?有何异同?答:(1)程序计数器PC作为不可寻址寄存器的特点程序计数器PC是中央控制器申最基本的寄存器,是一个独立的计数器,存放着下一条将程序存储器中取出的指令的地址。程序计数器PC变化的轨迹决定程序的流程。程序计数器的宽度决定了程序存储器可以寻址的范围。程序计数器PC的基本工作方式有:程序计数器PC自动加1。这是最基本的工作方式,也是这个专用寄存器被称为计数器的因素。执行条件或无条件转移指令时,程序计数器将被置入新的数值,程序的流向发生变化。变化的方式有下列几种:带符号的相对跳转SJMP、短跳转AJMP、长跳转1.JMP及JMPA+DPTR等。在执行调用指令或响应中断时:PC的现行值,即下一条将要执行的指令的地址送入堆栈,加以保护;将子程序的入口地址或者中断矢量地址送入PC,程序流向发生变化,执行子程序或中断服务程序;子程序或中断服务程序执行完毕,碰到返回指令RET或RETl时,将栈顶的内容送到PC寄存器中,程序流程又返回到本来的地方,继续执行。(2)地址指针DPTR的特点地址指针DPTR的特点是,它作为片外数据存储器寻址用的地址寄存器(间接寻址)。地址指针DPTR与程序计数器PC的异同相同之处: 两者都是与地址有关的、16位的寄存器。其中,PC与程序存储器的地址有关,而DPTR与数据存储器的地址有关。 作为地址寄存器使用时,PC与DPTR都是通过PO和P2口(作为16位地址总线)输出的。但是,PC的输出与A1.E及PSEN有关;DPTR的输出,则与A1.E、RD及WR相联系。不同之处: PC只能作为16位寄存器对待,由于有自动加1的功能,故又称为计数器;DPTR可以作为16位寄存器对待,也可以作为两个8位寄存器对待。 PC是不可以访问的,有自己独特的变化方式,它的变化轨迹决定了程序执行的流程;DPTR是可以访问的,如MoVDPTR,#XXXXH,INCDPTPo23.89C51端口锁存器的“读一修改一写”操作与“读引脚”操作有何区别?答:指令系统中有些指令读锁存器的值,有些指令则读引脚上的值。读锁存器指令是从锁存器中读取一个值并进行解决,把解决后的值(原值或已修改后的值)重新写入锁存器中。这类指令称为读-修改一写指令。对于读-修改一写指令。直接读锁存器而不是读端口引脚,是由于从引脚上读出的数据不一定能真正反映锁存器的状态。第三章1、 指令:CPU根据人的意图来执行某种操作的命令指令系统:一台计算机所能执行的所有指令集合机器语言:用二进制编码表达,计算机能直接辨认和执行的语言汇编语言:用助记符、符号和数字来表达指令的程序语言高级语言:独立于机器的,在编程时不需要对机器结构及其指令系统有进一步了解的通用性语言2、 见第1题3、简述8951的汇编指令格式。答:操作码目的操作数,源操作数4、简述8951的寻址方式和所能涉及的寻址空间。寻址方式王即数寻址直接寻址寄存器寻址寻址空间程序存储器ROM片内RAM低128B、特殊功能寄存器工作寄存器RO-R7、A、B、C、DPTR寄存器间接寻址变址寻址片内RAM低128B、片外RAM程序存储器(A+PC,A+DPTR)相对寻址程序存储器256B范围(PC+偏移量)位寻址片内RAM的20H-2FH字节地址、部分SFR5、访问特殊功能寄存器和外数据存储器,应采用那些寻址方式?答:SFR:直接寻址,位寻址,寄存器寻址;片外RAM:寄存器间接寻址6、8951中已知(30H)=38H,请分析以下各是什么指令,说明源操作数的寻址方式以及执行结果。MOVA,40H;直接寻址(40H)TAMOVRO,A;寄存器寻址(八)TROMOVP1,#0F0H;立即数寻址OFOTPlMOVR0,30H;直接寻址(30H)T(RO)MOVDPTR,#3848H;立即数寻址3848HDPTRMOV4OH,38H;直接寻址(38H)40HMOVRO,30H;直接寻址(30H)TROMOVPO,RO;寄存器寻址(RO)TPoMOV18H,#30H;立即数寻址30HT18HMOVA,R0;寄存器间接寻址(RO)TAMOVP2,P1;直接寻址(PI)TP2最后结果:(RO)=38H,(八)=40H,(PO)=38H,(P1)=(P2)=OFOH,(DPTR)=3848H,(18H)=30H,(30H)=38H,(38H)=40H,(40H)=40H,(48H)=38H注意:T左边是内容,右边是单元7、8951片内高128字节的地址寻址要注意什么/?答:用直接寻址,位寻址,寄存器寻址8、指出些列指令的本质?MOVA,DATA;直接寻址2字节1周期MOVA,#DATA;立即数寻址2字节1周期MOVDATA1,DATA2;直接寻址3字节2周期MOV74H,#78H;立即数寻址3字节2周期假如想查某一指令的机器码,字节数或周期数可查阅书本后面的附录A9、设RO的内容分为32H,A的内容为48H,。请指出在执行下列程序段后上述各单元内容的变化?MOVA,R0;(RO)=80HTAMOVR0,40H;(40H)=08HT(RO)MOV40H,A;(八)=80H40HMOVR0,#35H;35H->R0最后结果:(RO)=35H(八)=80H,(32H)=08H,(40H)=80H10、如何访问SFR,可采用那些寻址方式?答:用直接寻址,位寻址,寄存器寻址11、如何访问片外RAM,可使用那些寻址方式?答:只能采用寄存器间接寻址(用MOVX指令)12、如何访问片内RAM,可使用那些寻址方式?答:低128字节:直接寻址,位寻址,寄存器间接寻址,寄存器寻址(R(TR7)高128字节:直接寻址,位寻址,寄存器寻址13、如何访问片内外程序存储器,可使用那些寻址方式?答:采用变址寻址(用MOVC指令)14、说明十进制调整的因素和方法?答:压缩BCD码在进行加法运算时应逢十进一,而计算机只将其当作十六进制数解决,此时得到的结果不对的。用DAA指令调整(加06H,60H,66H)15、说明8951布尔机解决机功能?答:用来进行位操作16、AN1.A,#17HOR1.17H,AXR1.A,R0CP1.A所以(八)=CBH;83H17H=O3HA;34HV03H=37H17H;03H37H=34H;34H求反等于CBH17、(I)SETBACCO或SETBEOH;EOH是累加器的地址C1.RACC.7C1.RACC.6C1.RACC.5C1.RACC.4(3)C1.RACC.6C1.RACC.5C1.RACC.4C1.RACC.318、 MOV27H,R7MOV26H,R6MOV25H,R5MOV24H,R4MOV23H,R3MOV22H,R2MOV21H,R1MOV20H,RO19、 MOV2FH,20MOV2EH,21MOV2DH,2220、编程,进行两个16位数的减法:6F5DHT3B4H,结果存入内部RAM的30和31H单元,30H存低八位。C1.RCMOVA,#5DH;被减数的低8位TAMOVR2,#B4H;减数低8位TR2SUBBA,R2;被减数减去减数,差TAMOV30H,AMOVA,#6FH;低8位结果T30H;被减数的高8位TASUBBA,R2;被减数减去减数,差TAMOV31H,A;高8位结果T30H注意:假如在你的程序中用到了进位位,在程序开始的时候要记得清0进位位21、编程,若累加器A满足下列条件,则程序转至1.ABE1.存储单元,设A中为无符号数。;(八)与10比较,不等转1.l;相等转1.ABE1.;(八)大于10,转1.ABE1.I) )AelOCJNEA,#0AH,1.11.JMP1.ABE1.II) JNC1.ABE1.或者:C1.RCSUBBA,#0AHJNC1.ABE1.(2)A>10CJNEA,#OAH,1.1RET;(八)与10比较,不等转1.l;相等结束;(八)大于10,转1.ABE1.;(八)小于10,结束1.1:JNC1.ABE1.RET或者:C1.RCSUBBA,#OAHJNC1.1RET1.1:JNZ1.ABE1.RET(八)与10比较,不等转1.l;相等转1.ABE1.(八)小于10,转1.2(3)A10CJNEA,#OAH,1.11.2:1.JMP1.ABE1.1.1:JC1.2RET或者:C1.RCSUBBA,#OAHJC1.ABE1.JZ1.ABE1.RET22、 (SP)=23H,(PC)=3412H参看书上80页23、 (SP)=27H,(26H)=48H,(27H)=23H,(PC)=3456H参看书上79页24、不能。ACA1.1.是短转指令,可调用的地址范围是2KB。在看这个题的时候同时看一下AJMP指令。同时考虑调用指令ACA1.1.和1.CA1.1.指令和RET指令的关系。25、编程,查找内部RAM中20H-50H单元中是否有OAAH这一数据,若有则将51h单元置为01H,如无,则将51H单元清零。MOVR2,#31H;数据块长度TR21.OOP:MOVA,R0;待查找的数据TAC1.RSUBBA,#0AAH;待查找的数据是OAAH吗1.1;是,转1.lRO;不是,地址增1,指向下一个待查数据DJNZR2,1.OOP;数据块长度减1,不等于0,继续查找MOV51H,#00H;等于0,未找到,OoHT51HRET1.1:MOV51H,#01H;找到,01H51HRET26、编程查找内部RAM的20H-50H单元中出现OOH的次数并将结果存入51H中。MOVR2,#31H;数据块长度TR2MOVRO,#20H;数据块首地址TRO1.OOP:MOVA,R0;待查找的数据TAJNZ;不为0,转1.l51H;为0,OOH个数增11.1:INC;地址增1,指向下一个待查数据DJNZR2,1.OOP;数据块长度减1,不等于0,继续查找RET27、外部数据RAM中有一个数据块,首地址为SOURCE,规定将该数据传送到内部RAM以DlST开头的区域在,直到碰到数字字符¥时结束。MOVDPTR,#SOURCE;源首地址TDPTRMOVR0,#DIST;目的首地址TRO1.OOP:MOVXA,DPTR;传送一个字符MOVRO,AINCDPTRINCROCJNEA,#24H,1.OOP个字符RET;指向下一个字符;传送的是字符吗?不是,传送下一28、已知R3和R4中存有一个十六位的二进制数,高位在3中,低位在4中,编程求其补,并存回原处。MOVA,R3;取该数高8位TAAN1.A,#80H;取出该数符号判断JZ1.1;是正数,转1.lMOVA,R4CP1.AADDA,#01HMOVR4,AMOVA,R3CP1.A;是负数,将该数低8位TA;低8位取反;加1;低8位取反加1后TR4;将该数高8位TA;高8位取反ADDCA,#00H;加上低8位加1时也许产生的进位MOVR3,A;高8位取反加1后TR31.1:RET29、已知30H和31H中存有一个十六位的二进制数,高位在前,低位在后,编程将它们乘2,并存回原处。C1.RC;清进位位CMOVA,31H;取该数低8位TAR1.CA;带进位位左移1位MOV31H,A;结果存回31HMOVA,30H;取该数高8位TAR1.C;带进位位左移1位MOV30H,A;结果存回30H30、内存中有两个4字节以压缩的BCD码形式存放的十进制数,一个放在30H-33H的单元中,一个放在40H-43H的单元中,编程求他们的和,结果放在30H-33H的单元中。MOVR2,#04H;字节长度TR2MOV;一个加数首地址TROMOVR1,#40H;另一个加数首地址TRlC1.R1.OOP:MOVA,R0;取一个加数;两个加数带进位位相加DA;十进制调整MOVR0,AINCRO;指向下一个字节INCR1DJNZR2,1.OOP;数据块长度减1,不等于0,继续查找RET31、编程,把片外RAM从2023H开始存放的8个数传送到片内30H开始的单元中。MOVR2,#08H;数据块长度TR2MOVRO,#30H;数据块目的地址TRoMOVDPTR,#2023H;数据块源地址TDPTR1.OOP:MOVXA,DPTR;传送一个数据MOVR0,AINCDPTR;指向下一个数据INCRO;DJNZR2,1.OOP;数据块长度减1,RET35、解:(100OH)=53H(1003H)=52H(1006H)=34H(1009H)=70H(1001H)=54H(1004H)=54H(1007H)=30H没传送完,继续传送(1002H)=41H(1005H)=12H(1008H)=OOH36、阅读下列程序说明其功能MOVR0,#40HMOVA,R0INCROADDA,R0INCROMOVR0,AC1.RAADDCA,#0INCROMOVR0,A;40HR0;98HA;41HR0;98H+(41H)=47H-÷A;结果存入42H单元;清A;进位位存入A;进位位存入43H功能:将40H,41H单元中的内容相加结果放在42H单元,进位放在43H单元,(RO)=43H,(八)=1,(40H)=98H,(41H)=AFH,(42H)=47H,(43H)=01H37、同上题MOVA,61H;F2HTAMOVB,#02H;02HBMU1.AB;F2H×02H=E4HHAADDA,62H;积的低8位加上CCHTAMOV63H,AC1.RAADDCA,BMOV64H,A;结果送62H;清A;积的高8位加进位位TA;结果送64H功能:将61H单元的内容乘2,低8位再加上62H单元的内容放入63H,将结果的高8位放在64H单元。(八)=02H,(B)=01H,(61H)=F2H,(62H)=CCH,(63H)=BOH,(64H)=02H39、 MOVA,XXHOR1.A,#80HMOVXXH,A40、 (2)MOVA,XXHMOVR0,AXR1.A,RO第五章1、什么是中断和中断系统?其重要功能是什么?答:当CPU正在解决某件事情的时候,外部发生的某一件事件请求CPU迅速去解决,于是,CPU暂时中止当前的工作,转去解决所发生的事件,中断服务解决完该事件以后,再回到本来被终止的地方,继续本来的工作。这种过程称为中断,实现这种功能的部件称为中断系统。功能:(1)使计算机具有实时解决能力,能对外界异步发生的事件作出及时的解决(2) 完全消除了CPU在查询方式中的等待现象,大大提高了CPU的工作效率(3) 实现实时控制2、试编写一段对中断系统初始化的程序,使之允许INTO,INT1,TO,串行口中断,且使TO中断为高优先级中断。解:MOVIE,#097HMOVIP,#02H3、在单片机中,中断能实现哪些功能?答:有三种功能:分时操作,实时解决,故障解决4、89C51共有哪些中断源?对其中端请求如何进行控制?答:(1)89C51有如下中断源:外部中断0请求,低电平有效:外部中断1请求,低电平有效T0:定期器、计数器0溢出中断请求T1:定期器、计数器1溢出中断请求TX/RX:串行接口中断请求(2)通过对特殊功能寄存器TCON、SCON、IE、IP的各位进行置位或复位等操作,可实现各种中断控制功能5、什么是中断优先级?中断优先解决的原则是什么?答:中断优先级是CPU相应中断的先后顺序。原则:(1) 先响应优先级高的中断请求,再响应优先级低的(2) 假如一个中断请求已经被响应,同级的其它中断请求将被严禁(3) 假如同级的多个请求同时出现,则CPU通过内部硬件查询电路,按查询顺序拟定应当响应哪个中断请求查询顺序:外部中断OT定期器O中断T外部中断IT定期器1中断T串行接口中断6、说明外部中断请求的查询和响应过程。答:当CPU执行主程序第K条指令,外设向CPU发出中断请求,CPU接到中断请求信号并在本条指令执行完后,中断主程序的执行并保存断点地址,然后转去响应中断。CPU在每个S5P2期间顺序采样每个中断源,CPU在下一个机器周期S6期间按优先级顺序查询中断标志,假如查询到某个中断标志为1,将在接下来的机器周期Sl期间按优先级进行中断解决,中断系统通过硬件自动将相应的中断矢量地址装入PC,以便进入相应的中断服务程序。中断服务完毕后,CPU返回到主程序第K+1条指令继续执行。7、89C51在什么条件下可响应中断?答:(1) 有中断源发出中断请求(2) 中断中允许位EA=1.即CPU开中断(3) 申请中断的中断源的中断允许位为1,即中断没有被屏蔽(4) 无同级或更高级中断正在服务(5) 当前指令周期已经结束(6) 若现行指令为RETI或访问IE或IP指令时,该指令以及紧接着的另一条指令已执行完毕8、简述89C51单片机的中断响应过程。答:CPU在每个机器周期S5P2期间顺序采样每个中断源,CPU在下一个机器周期S6期间按优先级顺序查询中断标志,如查询到某个中断标志为1,将在接下来的机器周期Sl期间按优先级进行中断解决,中断系统通过硬件自动将相应的中断矢量地址装入PC,以便进入相应的中断服务程序。一旦响应中断,89C51一方面置位相应的中断“优先级生效”触发器,然后由硬件执行一条长调用指令,把当前的PC值压入堆栈,以保护断点,再将相应的中断服务的入口地址送入PC,于是CPU接着从中断服务程序的入口处开始执行。对于有些中断源,CPU在响应中断后会自动清除中断标志。9、在89C51内存中,应如何安排程序区?答:主程序一般从0030H开始,主程序后一般是子程序及中断服务程序。在这个大家还要清除各个中断的中断矢量地址。10、试述中断的作用及中断的全过程。答:作用:对外部异步发生的事件作出及时的解决过程:中断请求,中断响应,中断解决,中断返回11、当正在执行某一个中断源的中断服务程序时,假如有新的中断请求出现,试问在什么情况下可响应新的中断请求?在什么情况下不能响应新的中断请求?答:(1)符合以下6个条件可响应新的中断请求:a)有中断源发出中断请求b)中断允许位EAF,即CPU开中断C)申请中断的中断源的中断允许位为1,即中断没有被屏蔽d)无同级或更高级中断正在被服务e)当前的指令周期已结束f)若现行指令为RETI或访问IE或IP指令时,该指令以及紧接着的另一条指令已被执行完12、89C51单片机外部中断源有几种触发中断请求的方法?如何实现中断请求?答:有两种方式:电平触发和边沿触发电平触发方式:CPU在每个机器周期的S5P2期间采样外部中断引脚的输入电平。若为低电平,使IEI(IEo)置“1”,申请中断;若为高电平,则IEl(IEO)清零。边沿触发方式:CPU在每个机器周期S5P2期间采样外部中断请求引脚的输入电平。假如在相继的两个机器周期采样过程中,一个机器周期采样到外部中断请求为高电平,接着下一个机器周期采样到外部中断请求为低电平,则使IEI(IEO)置“1”申请中断;否则,IEI(IEo)置0。13、89C51单片机有五个中断源,但只能设立两个中断优先级,因此,在中断优先级安排上受到一定的限制。试问以下几种中断优先顺序的安排(级别由高到低)是否也许:若也许,则应如何设立中断源的中断级别:否则,请简述不也许的理由。(1)定期器0,定期器1,外中断0,外中断1,串行口中断。可以,MOVIP,#0AH(2)串行口中断,外中断0,定期器0,外中断1,定期器1o可以,MOVIP,#10H(3)外中断0,定期器1,外中断1,定期器0,串行口中断。不可以,只能设立一级高级优先级,假如将INTo,T1设立为高级,而To级别高于INT1.(4)外中断0,外中断1,串行口中断,定期器0,定期器1。可以,MOVIP,#15H(5)串行口中断,定期器0,外中断0,外中断1,定期器1。不可以(6)外中断0,外中断1,定期器0,串行口中断,定期器1。不可以(7)外中断0,定期器1,定期器0,外中断1,串行口中断。可以,MOVIP,#09H14、89C51各中断源的中断标志是如何产生的?又是如何清0的?CPU响应中断时,中断入口地址各是多少?答:各中断标志的产生和清“0”如下:(1) 外部中断类外部中断是由外部因素引起的,可以通过两个固定引脚,即外部中断。和外部中断1输入信号。外部中断。请求信号,由P3.2脚输入。通过ITo来决定中断请求信号是低电平有效还是下跳变有效。一旦输入信号有效,则向CPU申请中断,并且使IEo=1。硬件复位。外部中断1请求信号,功能与用法类似外部中断0(2) 定期中断类定期中断是为满足定期或计数溢出解决需要而设立的。当定期器/计数器中的计数结构发生计数溢出的,即表白定期时间到或计数值已满,这时就以计数溢出信号作为中断请求,去置位一个溢出标志位。这种中断请求是在单片机芯片内部发生的,无需在芯片上设立引入端,但在计数方式时,中断源可以由外部引入。TF0:定期器To溢出中断请求。当定期器To产生溢出时,定期器TO请求标志TF0=1,请求中断解决。使用中断时由硬件复位,在查询方式下可由软件复位。TF1:定期器Tl溢出中断请求。功能与用法类似定期器TO(3) 串行口中断类串行口中断是为串行数据的传送需要而设立的。串行中断请求也是在单片机芯片内部发生的,但当串行口作为接受端时,必须有一完整的串行帧数据从Rl端引入芯片,才也许引发中断。Rl或TI:串行口中断请求。当接受或发送一串帧数据时,使内部串行口中断请求标志Rl或Tl=1,并请求中断。响应后必须软件复位。CPU响应中断时,中断入口地址如下:中断源入口地址