欢迎来到课桌文档! | 帮助中心 课桌文档-建筑工程资料库
课桌文档
全部分类
  • 党建之窗>
  • 感悟体会>
  • 百家争鸣>
  • 教育整顿>
  • 文笔提升>
  • 热门分类>
  • 计划总结>
  • 致辞演讲>
  • 在线阅读>
  • ImageVerifierCode 换一换
    首页 课桌文档 > 资源分类 > DOCX文档下载  

    单片机原理及接口技术习题答案第四版李朝青修订后.docx

    • 资源ID:1363005       资源大小:101.91KB        全文页数:51页
    • 资源格式: DOCX        下载积分:5金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要5金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    单片机原理及接口技术习题答案第四版李朝青修订后.docx

    单片机原理及接口技术课后习题答案(第四版)李朝青第一章1 .什么是微解决器(CPU)、微机和单片机?答微解决器自身不是计算机,但它是小型计算机或微机的控制和解决部分。微机则是具有完整运算及控制功能的计算机,除了微解决器外还涉及存储器、接口适配器以及输入输出设备等。单片机是将微解决器、一定容量的RAM、ROM以及I/O口、定期器等电路集成在一块芯片上,构成的单片微型计算机。2 .单片机具有哪些特点(1)片内存储容量越来越大。(2抗干扰性好,可靠性高。(3)芯片引线齐全,容易扩展。(4)运营速度高,控制功能强。(5)单片机内部的数据信息保存时间很长,有的芯片可以达成12023以上。3 .微型计算机如何执行一个程序?答:通过CPlJ指令,提到内存当中,再逐个执行。4 .微型计算机由那几部分构成?微解决器,存储器,接口适配器(即I/O接口),I/O设备第二章1. 89C51单片机内包含哪些重要逻辑功能部件?答:80C51系列单片机在片内集成了以下重要逻辑功能部件:(I)CPU(中央解决器):8位(2)片内RAM:128B(3)特殊功能寄存器:21个(4)程序存储器:4KB(5)并行I/O口:8位,4个(6)串行接口:全双工,1个(7)定期器/计数器:16位,2个(8)片内时钟电路:1个2. 89C51的EA端有何用途?答:/EA端接高电平时,CPU只访问片内并执行内部程序,存储器。/EA端接低电平时,CPU只访问外部ROM,并执行片外程序存储器中的指令。/EA端保持高电平时,CPU执行内部存储器中的指令。3. 89C51的存储器分哪几个空间?如何区别不同空间的寻址?答: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区从00lFFH(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)中的RSI和RSO可以给出4中组合用来从4组工作寄存器组中进行选择PSW属于SFR(SpecialFunctionRegister)(特殊功能寄存器)8. 89C51PO口用作通用I/O口输入时,若通过TT1.“0C”门输入数据,应注意什么?为什么?答:应当要接一个上拉电阻9. 读端口锁存器和“读引脚”有何不同?各使用哪种指令?答:读锁存器(AN1.PO,A)就是相称于从存储器中拿数据,而读引脚是从外部拿数据(如M(WA,Pl这条指令就是读引脚的,意思就是把端口pl输入数据送给A)传送类MOV,判位转移JB、JNB、这些都属于读引脚,平时实验时经常用这些指令于外部通信,判断外部键盘等;字节互换XCH、XCHD算术及逻辑运算OR1.、CP1.、AN1.sADD、ADDCsSUBB、INC、DEC控制转移CJNE、DJNZ都属于读锁存器。10.89C51P0P3口结构有何不同?用作通用1/0口输入数据时,应注意什么?答:PO口内部没有上拉电阻,可以用做16位地址的低8位;P3有第二功能;P2口可以用做16位地址的高8位;需要上拉电阻。OC门电路无法输出高低电平,只有靠上拉电阻才干实现11 .89C51单片机的EA信号有何功能?在使用8031时,EA信号引脚应如何解决?答:(l)80C51单片机的EA信号的功能EA为片外程序存储器访问允许信号,低电平有效;在编程时,其上施加21V的编程电压EA引脚接高电平时,程序从片内程序存储器开始执行,即访问片内存储器;EA引脚接低电平时,迫使系统所有执行片外程序存储器程序。(2)在使用80C31时,EA信号引脚的解决方法由于80C31没有片内的程序存储器,所以在使用它时必然要有外部的程序存储器,EA信号引脚应接低电平。12 .89C51单片机有哪些信号需要芯片引脚以第2功能的方式提供?答:第一功能第二功能串行口:P3.0RXD(串行输入口)中断:P3.2INTO外部中断0P3.3INTl外部中断1定期器/计数器(TO、T1):P3.4TO(定期器/计数器0的外部输入)P3.5Tl(定期器/计数器1的外部输入)数据存储器选通:P3.6WR(外部存储器写选通,低电平有效,输出)P3.7RD(外部存储器读选通,低电平有效,输出)定期器/计数器(T2):P1.OT2(定期器T2的计数端)Pl.1T2EX(定期器T2的外部输入端)P3.1TXD(串行输出口)13 .内部RAM低128字节单元划分为哪3个重要部分?各部分重要功能是什么?答:片内RAM低128单元的划分及重要功能:(1)工作寄存器组(OOH1FH)这是一个用寄存器直接寻址的区域,内部数据RAM区的031(00HlFH),共32个单元。它是4个通用工作寄存器组,每个组包含8个8位寄存器,编号为R(TR7。(2)位寻址区(20H2FH)从内部数据RAM区的3247(20H2FH)的16个字节单元,共包含128位,是可位寻址的RAM区。这16个字节单元,既可进行字节寻址,又可实现位寻址。(3)字节寻址区(30H7FH)从内部数据RAM区的48127(30H7FH),共80个字节单元,可以采用间接字节寻址的方法访问。14 .使单片机复位有几种方法?复位后机器的初始状态如何?答:(1)单片机复位方法单片机复位方法有:上电自动复位、按键手动复位和两种方式(2)复位后的初始状态复位后机器的初始状态,即各寄存器的状态:PC之外,复位操作还对其他一些特殊功能寄存器有影响,它们的复位状态如题表2-1所例15 .开机复位后,CPU使用的是哪组工作寄存器?它们的地址是什么?CPU如何拟定和改变当前工作寄存器组?答:一般开机复位后都是选择第一组通用工作寄存器作为工作寄存器的,一共有4组,分别为0.1.2.3连续位于OOh到IFH地址,然后在机器中有个程序状态字PSW,它的第四和第三位RSI,RSO是用来选择工作寄存器组的,也许不同机器地址稍有不同。他们俩的值和寄存器组的关系:RS1/RS00/00/11/01/1使用的工作寄存器Ol23地址00-0708-0F10-1718-1F写程序的时候就是通过定义程序状态字来选择使用不同的寄存器组。也可以直接对RSI和RSO赋值。(最后一问同题7)16 .程序状态寄存器PSW的作用是什么?常用标志有哪些位?作用是什么?答:PSW是一个SFR(特殊功能寄存器)位于片内RAM的高128B具体地址DoH(OOHFFH)(片内RAM的编址)(8bits编址方法)PSW=ProgramStatusWord(程序状态字)PSW的常用标志位有哪些?CY=Carry(进位标志位)AC=AuxiliaryCarry(辅助进位标志位)(半进位标志位)FO用户标志位RSbRSO,用来选择当前工作寄存器组(R(TR7)(4选1)OV=Overflow(溢出标志位)P=Parity(奇偶校验位)17 .位地址7CH与字节地址7CH如何区别?位地址7CH具体在片内RAM中的什么位置?答:用不同的寻址方式来加以区分,即访问128个位地址用位寻址方式,访问低128字节单元用字节寻址和间接寻址。具体地址为2F的第五位,即为7C。18 .89C51单片机的时钟周期与振荡周期之间有什么关系?什么叫机器周期和指令周期?答:时钟信号的周期称为机器状态周期,是振荡周期的两倍。一个机器周期是指CPU访问存储器一次所需的时间。指令周期是执行一条指令所需的时间。19 .一个机器周期的时序如何划分?答:一个机器周期=12个震荡周期二6个时钟周期(状态周期)SlPl,S1P2,S2P1,S2P2,S3P1,S3P2,S4P1,S4P2,S5P1,S5P2,S6P1,S6P2其中s=state(状态),p=phase(相位)20 .什么叫堆栈?堆栈指针SP的作用是什么?89C51单片机堆栈的容量不能超过多少字节?答:堆栈都是一种数据项按序排列的数据结构,只能在一端(称为栈顶(top)对数据项进行插入和删除。要点:堆:顺序随意栈:后进先出(1.aStTnFirst-OUt)在调用子程序时需要保存调用函数的CPU寄存器PC指针,PC指针是被CA1.1.指令自动压入SP所指向的片内存储器,CPU寄存器要由用户用PUSH指令自行保存,因此SP的作用就是一个指针,当进行中断调用,子函数调用时将现场数据压入SP所指向的存储器,SP自动增长1或2,当中断结束RETI,调用返回RET,POP时将SP数据弹出,SP自动减1或,28051最大为128字节的片内存储器,21 .89C51有几种低功耗方式?如何实现?答:空闲方式和掉电方式空闲方式和掉电方式是通过对SFR中的PCoN(地址87H)相应位置1而启动的。当CPU执行完置ID1.=I(PCONj)的指令后,系统进入空闲工作方式。这时,内部时钟不向CPU提供,而只供应中断、串行口、定期器部分。CPU的内部状态维持,即涉及堆栈指针SP、程序计数器PC、程序状态字PSM累加器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、长跳转IJMP及JMPA+DPTR等。在执行调用指令或响应中断时:PC的现行值,即下一条将要执行的指令的地址送入堆栈,加以保护;将子程序的入口地址或者中断矢量地址送入PC,程序流向发生变化,执行子程序或中断服务程序;子程序或中断服务程序执行完毕,碰到返回指令RET或RETl时,将栈顶的内容送到PC寄存器中,程序流程又返回到本来的地方,继续执行。(2)地址指针DPTR的特点地址指针DPTR的特点是,它作为片外数据存储器寻址用的地址寄存器(间接寻址)。(3)地址指针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、操作码目的操作数,源操作数4、寻址方式寻址空间立即数寻址程序存储器ROM直接寻址片内RAM低128B、特殊功能寄存器寄存器寻址工作寄存器R0-R7、A、B、C、DPTR寄存器间接寻址片内RAM低128B、片外RAM变址寻址程序存储器(A+PC,A+DPTR)相对寻址程序存储器256B范围(PC+偏移量)位寻址片内RAM的20H-2FH字节地址、部分SFR5、要访问特殊功能寄存器和片外数据存储器,应采用哪些寻址方式?答SFR:直接寻址,位寻址,寄存器寻址;片外RAM:寄存器间接寻址6、MOVA,40H;直接寻址(40H)-AMOVRO,A;寄存器寻址(八)-RoMOVPl,#0F0H;立即数寻址OFOfPlMOVR0,30H;直接寻址(30H)(RO)MOVDPTR,#3848H;立即数寻址3848HfDpTRMOV40H,38H;直接寻址(38H)-40HMOVR0,30H;直接寻址(30H)-ROMOVPO,RO;寄存器寻址(RO)-PoMOV18H,#30H;立即数寻址30H-18HMOVA,R0;寄存器间接寻址(Ro)fAMOVP2,Pl;直接寻址(PI)P2最后结果:(Ro)=38H,(八)=40H,(PO)=38H,(Pl)=(P2)=OFOH,(DPTR)二3848H,(18H)=30H,(30H)=38H,(38H)=40H,(40H)=40H,(48H)=38H注意:一左边是内容,右边是单元7、对89C51/S51片内RAM的高128字节的地址空间寻址要注意什么?答用直接寻址,位寻址,寄存器寻址8、指出下列指令的本质区别?MOVA,DATA;直接寻址2字节1周期MOVA,#DATA;立即数寻址2字节1周期MOVDATA1,DATA2;直接寻址3字节2周期MOV74H,#78H;立即数寻址3字节2周期假如想查某一指令的机器码,字节数或周期数可查阅书本后面的附录A9、MOVA,R0;(RO)=80HfAMOVR0,40H;(40H)=O8H-(RO)MOV40H,A;(八)=80->40HMOVR0,#35H;35H->R0最后结果:(RO)=35H(八)=80H,(32H)=08H,(40H)=80H10、如何访问SFR?用直接寻址,位寻址,寄存器寻址Ik如何访问片外RAM?只能采用寄存器间接寻址(用MOVX指令)12、如何访问片内RAM?低128字节:直接寻址,位寻址,寄存器间接寻址,寄存器寻址(R0R7)高128字节:直接寻址,位寻址,寄存器寻址13、如何访问片内外RoM?采用变址寻址(用MC)VC指令)14、说明十进制调整的因素和方法答:压缩BCD码在进行加法运算时应逢十进一,而计算机只将其当作十六进制数解决,此时得到的结果不对的。用DAA指令调整(加06H,60H,66H)15、说明89C51/S51的布尔解决机功能答:用来进行位操作16、AN1.A,#17HOR1.17H,A;83H17H=03H-*AXR1.A,R0CP1.A所以(八)=CBH;03H37H=34H;34H求反等于CBH;34HV03H=37H->17H17、(1)SETBACC.0sKSETBEOH;EOH是累加器的地址(2)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,RlMOV20H,RO19、MOV2FH,20MOV2EH,21MOV2DH,2220、C1.RCMOVA,#5DHMOVR2,#B4HSUBBA,R2MOV30H,AMOVA,#6FHMOVR2,#13HSUBBA,R2MOV31H,A;被减数的低8位一A;减数低8位fR2;被减数减去减数,差一A;低8位结果f30H;被减数的高8位fA;减数高8位fR2;被减数减去减数,差fA;高8位结果一30H注意:假如在你的程序中用到了进位位,在程序开始的时候要记得清0进位位21、(1)AelOCJNEA,#0AH,1.l;(八)与10比较,不等转1.l1.JMP1.ABE1.;相等转1.ABE1.1.I:JNC1.ABE1.;(八)大于10,转1.ABE1.或者:C1.RCSUBBA,#0AHJNC1.ABE1.(2)A>10CJNEA,#0AH,1.lRET1.I:JNC1.ABE1.RET或者:C1.RCSUBBA,#0AHJNC1.lRET1.I:JNZ1.ABE1.RET(3)A1OCJNEA,#0AH,1.l1.2:1.JMP1.ABE1.1.I:JC1.2RET或者:C1.RCSUBBA,#0AHJC1.ABE1.;(八)与IO比较,不等转1.l;(八)大于10,转1.ABE1.;(八)小于10,结束;(八)与10比较,不等转1.l;相等转1.ABE1.;(八)小于10,转1.2JZ1.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、MOVR2,#31H;数据块长度一R2MOVRO,#20H;数据块首地址一RO1.OOP:MOVA,R0;待查找的数据一AC1.RC;清进位位SUBBA,#0AAH;待查找的数据是OAAH吗JZ1.l;是,转1.IINCRO;不是,地址增1,指向下一个待查数据DJNZR2,1.OOP;数据块长度减1,不等于0,继续查找MOV51H,#00H;等于0,未找到,00H->51HRET1.I:M0V51H,#01H;找到,01H-51HRET26、MOVR2,#31H;数据块长度一R2MOVRO,#20H;数据块首地址一RO1.OOP:MOVA,R0;待查找的数据fAJNZ1.l;不为0,转1.lINC51H;为O,OOH个数增11.I:INCRO;地址增1,指向下一个待查数据DJNZR2,1.OOP;数据块长度减1,不等于0,继续查找RET27、MOVDPTR,#SOURCEMOVRO,#DIST1.OOP:MOVXA,DPTRMOVR0,AINCDPTRINCROCJNEA,#24H,1.OOP;源首地址fDPTR;目的首地址一RO;传送一个字符;指向下一个字符;传送的是字符吗?不是,传送下一个字符RET28、MOVA,R3AN1.A,#80HJZ1.lMOVA,R4CP1.AADDA,#01HMOVR4,AMOVA,R3;取该数高8位fA;取出该数符号判断;是正数,转1.l;是负数,将该数低8位一A;低8位取反;加1;低8位取反加1后一R4;将该数高8位一ACP1.AADDCA,#00H;加上低8位加1时也许产生的进位MOVR3,A;高8位取反加1后一R31.1:RET29、C1.RC;清进位位CMOVA,31H;取该数低8位fAR1.CA;带进位位左移1位MOV31H,A;结果存回31HMOVA,30H;取该数高8位一AR1.CA;带进位位左移1位MOV30H,A;结果存回30H30、MOVR2,#04H;字节长度fR2MOVRO,#30H;一个加数首地址ROMOVRl,#40H;另一个加数首地址fRlC1.RC;清进位位1.OOP:MOVA,R0;取一个加数ADDCA,R1;两个加数带进位位相加DAA;十进制调整MOVR0,A;存放结果INCRO;指向下一个字节INCRI;DJNZR2,1.OOP;数据块长度减1,不等于0,继续查找RETMOVRO,#30H;数据块目的地址-*ROMOVDPTR,#2023H;数据块源地址一DPTR1.OOP:MOVXA,DPTR;传送一个数据MOVR0,AINCDPTRINCRODJNZR2,1.OOPRETMOVRO,OFHMOVB,ROMOVRO,#OFHMOVB,R0MOVB,#OFH;指向下一个数据*9;数据块长度减1,没传送完,继续传送;2字节,2周期;2字节,2周期;2字节,1周期;2字节,2周期;3字节,2周期4字节4周期(差)4字节3周期(中)3字节2周期(好)33、(1)功能是将片内RAM中50H51H单元清0。(2)7A0A(大家可以看一下书上,对于立即数寻址的话,后面一个字节存放的是立即数)7850(第一个字节的后三位是寄存器,前一个条指令是OlO也就是指的R2,在这里是RO,所以应当是78,后一个字节存放的是立即数)DAFC(这里涉及到偏移量的计算,可以参考书上56页)34、INCR0;(7EH)=OOHINCRO;(RO)=7FHINCR0;(7FH)=39HINCDPTR;(DPTR)=IOFFHINCDPTR;(DPTR)=IlOOHINCDPTR;(DPTR)=IlOlH35、解:(100OH)=53H(1003H)=52H(1006H)=34H(1009H)=70H36、MOVRO,#40HMOVA,R0;INCRO(100lH)=54H(1004H)=54H(1007H)=30H;40HfRO98HfA;41H->R0(1002H)=41H(1005H)=12H(1008H)=OOHADDA,R0INCROMOVR0,AC1.RAADDCA,#0;98H+(41H)=47HfA;结果存入42H单元;清A;进位位存入AINCROMOVR0,A;进位位存入43H功能:将40H,41H单元中的内容相加结果放在42H单元,进位放在43H单元,(RO)=43H,(八)=1,(40H)=98H,(41H)=AFH,(42H)=47H,(43H)=OlH37、MOVA,61HMOVB,#02HMU1.ABADDA,62HMOV63H,A;F2H-A;02HfB;F2H×O2H=E4H-*A;积的低8位加上CCH-A;结果送62HC1.RAADDCA,B;积的高8位加进位位fAMOV64H,A;结果送64H功能:将61H单元的内容乘2,低8位再加上62H单元的内容放入63H,将结果的高8位放在64H单元。(八)=O2H,(B)=OlH,(61H)=F2H,(62H)=CCH,(63H)=BOH,(64H)=02H39、MOVA,XXHOR1.A,#80HMOVXXH,A40、(2)MOVA,XXHMOVRO,AXR1.A,RO第五章1、什么是中断和中断系统?其重要功能是什么?答:当CPU正在解决某件事情的时候,外部发生的某一件事件请求CPU迅速去解决,于是,CPU暂时中止当前的工作,转去解决所发生的事件,中断服务解决完该事件以后,再回到本来被终止的地方,继续本来的工作。这种过程称为中断,实现这种功能的部件称为中断系统。功能:(I)使计算机具有实时解决能力,能对外界异步发生的事件作出及时的解决(2) 完全消除了CPU在查询方式中的等待现象,大大提高了CPU的工作效率(3) 实现实时控制2、试编写一段对中断系统初始化的程序,使之允许INTO,INT1,TO,串行口中断,且使TO中断为高优先级中断。解:MOVIE,#097HMOVIP,#02H3、在单片机中,中断能实现哪些功能?答:有三种功能:分时操作,实时解决,故障解决4、89C51共有哪些中断源?对其中端请求如何进行控制?答:(1)89C51有如下中断源:外部中断0请求,低电平有效:外部中断1请求,低电平有效TO:定期器、计数器O溢出中断请求T1:定期器、计数器1溢出中断请求TX/RX:串行接口中断请求(2)通过对特殊功能寄存器TCON、SCON、IE、IP的各位进行置位或复位等操作,可实现各种中断控制功能5、什么是中断优先级?中断优先解决的原则是什么?答:中断优先级是CPU相应中断的先后顺序。原则:(1) 先响应优先级高的中断请求,再响应优先级低的(2) 假如一个中断请求己经被响应,同级的其它中断请求将被严禁(3) 假如同级的多个请求同时出现,则CPU通过内部硬件查询电路,按查询顺序拟定应当响应哪个中断请求查询顺序:外部中断O一定期器O中断一外部中断1一定期器1中断一串行接口中断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内存中,应如何安排程序区?答:主程序一般从003OH开始,主程序后一般是子程序及中断服务程序。在这个大家还要清除各个中断的中断矢量地址。10、试述中断的作用及中断的全过程。答:作用:对外部异步发生的事件作出及时的解决过程:中断请求,中断响应,中断解决,中断返回11、当正在执行某一个中断源的中断服务程序时,假如有新的中断请求出现,试问在什么情况下可响应新的中断请求?在什么情况下不能响应新的中断请求?答:(1)符合以下6个条件可响应新的中断请求:a) 有中断源发出中断请求b) 中断允许位EA=I,即CPU开中断c) 申请中断的中断源的中断允许位为1,即中断没有被屏蔽d) 无同级或更高级中断正在被服务e) 当前的指令周期已结束D若现行指令为RETI或访问IE或IP指令时,该指令以及紧接着的另一条指令己被执行完12、89C51单片机外部中断源有几种触发中断请求的方法?如何实现中断请求?答:有两种方式:电平触发和边沿触发电平触发方式:CPU在每个机器周期的S5P2期间采样外部中断引脚的输入电平。若为低电平,使IEl(IEO)置“1”,申请中断;若为高电平,则IEl(IEo)清零。边沿触发方式:CPU在每个机器周期S5P2期间采样外部中断请求引脚的输入电平。假如在相继的两个机器周期采样过程中,一个机器周期采样到外部中断请求为高电平,接着下一个机器周期采样到外部中断请求为低电平,则使IEl(IEo)置“1”申请中断;否则,IEl(IEO)置0。13、89C51单片机有五个中断源,但只能设立两个中断优先级,因此,在中断优先级安排上受到一定的限制。试问以下几种中断优先顺序的安排(级别由高到低)是否也许:若也许,则应如何设立中断源的中断级别:否则,请简述不也许的理由。(1)定期器0,定期器1,外中断0,外中断1,串行口中断。可以,MOVIR#0AH(2)串行口中断,外中断0,定期器0,外中断1,定期器1。可以,MOVIP,#IOH(3)外中断0,定期器1,外中断1,定期器0,串行口中断。不可以,只能设立一级高级优先级,假如将INTO,Tl设立为高级,而TO级别高于INT1.(4)外中断0,外中断1,串行口中断,定期器0,定期器1。可以,MOVIP,#15H(5)串行口中断,定期器0,外中断0,外中断1,定期器1。不可以(6)外中断0,外中断1,定期器0,串行口中断,定期器1。不可以外中断0,定期器1,定期器0,外中断1,串行口中断。可以,MOVIP,O9H14、89C51各中断源的中断标志是如何产生的?又是如何清0的?CPU响应中断时,中断入口地址各是多少?答:各中断标志的产生和清“0”如下:(1) 外部中断类外部中断是由外部因素引起的,可以通过两个固定引脚,即外部中断0和外部中断1输入信号。外部中断0请求信号,由P3.2脚输入。通过ITO来决定中断请求信号是低电平有效还是下跳变有效。一旦输入信号有效,则向CPU申请中断,并且使IEO=Io硬件复位。外部中断1请求信号,功能与用法类似外部中断0(2) 定期中断类定期中断是为满足定期或计数溢出解决需要而设立的。当定期器/计数器中的计数结构发生计数溢出的,即表白定期时间到或计数值已满,这时就以计数溢出信号作为中断请求,去置位一个溢出标志位。这种中断请求是在单片机芯片内部发生的,无需在芯片上设立引入端,但在计数方式时,中断源可以由外部引入。TFO:定期器TO溢出中断请求。当定期器TO产生溢出时,定期器TO请求标志TFO=1,请求中断解决。使用中断时由硬件复位,在查询方式下可由软件复位。TF1:定期器Tl溢出中断请求。功能与用法类似定期器To(3) 串行口中断类串行口中断是为串行数据的传送需要而设立的。串行中断请求也是在单片机芯片内部发生的,但当串行口作为接受端时,必须有一完整的串行帧数据从RI端引入芯片,才也许引发中断。Rl或TI:串行口中断请求。当接受或发送一串帧数据时,使内部串行口中断请求标志Rl或TI=I,并请求中断。响应后必须软件复位。CPU响应中断时,中断入口地址如下:中断源入口地址外部中断O0003H定期器TO中断OOoBH外部中断10013H定期器Tl中断(X)IBH串行口中断0023H15、中断响应时间是否为拟定不变的?为什么?答:中断响应时间不是拟定不变的。由于CPU不是在任何情况下对中断请求都予以响应的;此外,不同的情况对中断响应的时间也是不同的。下面以外部中断为例,说明中断响应的时间。在每个机器周期的S5P2期间,端的电平被所存到TCON的IEO位,CPU在下一个机器周期才会查询这些值。这时满足中断响应条件,下一条要执行的指令将是一条硬件长调用指令"1.CA1.1.w,使程序转入中断矢量入口。调用自身要用2个机器周期,这样,从外部中断请求有效到开始执行中断服务程序的第一条指令,至少需要3个机器周期,这是最短的响应时间。假如碰到中断受阻的情况,这中断响应时间会更长一些。例如,当一个同级或更高级的中断服务程序正在进行,则附加的等待时间取决于正在进行的中断服务程序:假如正在执行的一条指令还没有进行到最后一个机器周期,附加的等待时间为13个机器周期;假如正在执行的是RETl指令或者访问IE或IP的指令,则附加的等待时间在5个机器周期内。若系统中只有一个中断源,则响应时间为38个机器周期。16、中断响应过程中,为什么通常要保护现场?如何保护?答:由于一般主程序和中断服务程序都也许会用到累加器,PSW寄存器及其他一些寄存器。CPU在进入中断服务程序后,用到上述寄存器时,就会破坏它本来存在寄存

    注意事项

    本文(单片机原理及接口技术习题答案第四版李朝青修订后.docx)为本站会员(夺命阿水)主动上传,课桌文档仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知课桌文档(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-1

    经营许可证:宁B2-20210002

    宁公网安备 64010402000986号

    课桌文档
    收起
    展开