单片机原理及应用99092new_第1页
单片机原理及应用99092new_第2页
单片机原理及应用99092new_第3页
单片机原理及应用99092new_第4页
单片机原理及应用99092new_第5页
已阅读5页,还剩41页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、“单片机原理及应用”课程习题与解答参考教材:张毅刚主编,单片机原理及应用,普通高等教育“十五”国家级规划教材,高等教育出版社,2004年1月第一章13:单片机与普通计算机的不同之处在于其将( )( )和( )三部分集成于一块芯片上。答:CPU、存储器、I/O口18:8051与8751的区别是:A、内部数据存储但也数目的不同B、内部数据存储器的类型不同C、内部程序存储器的类型不同D、内部的寄存器的数目不同答:C第二章24:在MCS51单片机中,如果采用6MHz晶振,1个机器周期为( )。答:2us。析:机器周期为振荡周期的1/6。26:内部RAM中,位地址为30H的位,该位所在字节的字节地址为(

2、 )。答:26H27:若A中的内容为63H,那么,P标志位的值为( )。答:0析:P为偶校验位,因为A中1的个数为偶数,所以P=0。28:判断下列说法是否正确:A、8031的CPU是由RAM和EPROM所组成。B、区分片外程序存储器和片外数据存储器的最可靠的方法是看其位于地址范围的低端还是高端。C、在MCS-51中,为使准双向的I/O口工作在输入方式,必须保证它被事先预置为1。D、PC可以看成使程序存储器的地址指针。答:错、错、对、对29:8031单片机复位后,R4所对应的存储单元的地址为( ),因上电时PSW=( )。这时当前的工作寄存器区是( )组工作寄存器区。答:04H、00H、0211

3、:判断以下有关PC和DPTR的结论是否正确?A、DPTR是可以访问的,而PC不能访问。B、它们都是16位的存储器C、它们都有加1的功能。D、DPTR可以分为两个8位的寄存器使用,但PC不能。答:对、对、对、对213:使用8031芯片时,需将/EA引脚接( )电平,因为其片内无( )存储器。答:低、程序214:片内RAM低128个单元划分为哪3个主要部分?各部分的主要功能是什么?答:工作寄存器区、位寻址区、数据缓冲区215:判断下列说法是否正确A、 程序计数器PC不能为用户编程时直接使用,因为它没有地址。B、 内部RAM的位寻址区,只能供位寻址使用,而不能供字节寻址使用。C、 8031共有21个

4、特殊功能寄存器,它们的位都是可以用软件设置的,因此,是可以进行位寻址的。答:对、错、错216:PC的值是A、当前正在执行指令的前一条指令的地址B、当前正在执行指令的地址C、当前正在执行指令的下一条指令的地址D、控制器中指令寄存器的地址答:C217:通过堆栈操作实现子程序调用,首先就要把( )的内容入栈,以进行断点保护。调用返回时,再进行出栈保护,把保护的断点送回到( )。答:PC、PC219:MCS51单片机程序存储器的寻址范围是由程序计数器PC的位数所决定的,因为MCS51的PC是16位的,因此其寻址的范围为( )KB。答:64220:当MCS51单片机运行出错或程序陷入死循环时,如何来摆脱

5、困境?答:软件陷阱、复位221:判断下列说法是否正确?A、 PC是1个不可寻址的特殊功能寄存器。B、 单片机的主频越高,其运算速度越快。C、 在MCS51单片机中,1个机器周期等于1us。D、特殊功能寄存器SP内装的是栈顶首地址单元的内容。答:错、对、错、错222:如果手中仅有一台示波器,可通过观察哪个引脚的状态,来大致判断MCS51单片机正在工作?答:ALE析:因为单片机正常工作时,ALE脚输出时钟频率为振荡周期的1/6。第三章31:判断下列指令的正误:1)MOV 28H,R2 2)DEC DPTR 3)INC DPTR 4)CLR R05)CPL R5 6)MOV R0,R1 7)PUSH

6、 DPTR 8)MOV F0,C9)MOV F0,ACC.3 10)MOVX A,R1 11)MOV C,30H 12)RLC R0答:错、错、对、错 错、错、错、对 错、对、对、错32:判断下列说法是否正确。A、 立即寻址方式是被操作的数据本身在指令中,而不是它的地址在指令中。B、 指令周期是执行一条指令的时间。C、 指令中直接给出的操作数称为直接寻址。答:对、对、错33:在基址加变址寻址方式中,以( )作变址寄存器,以( )或( )作基址寄存器。答:累加器A,DPTR、PC37:指令格式是由( )和( )所组成,也可能仅由( )组成。答:操作码、操作数、操作码38:假定累加器A中的内容为3

7、0H,执行指令1000H:MOVC A,A+PC后,把程序存储器( )单元的内容送入累加器A中。答:1031H39:在MCS51中,PC和DPTR都用于提供地址,但PC是为访问( )存储器提供地址,而DPTR是为访问( )存储器提供地址。答:程序、数据310:在寄存器间接寻址方式中,其“间接”体现在指令中寄存器的内容不是操作数,而是操作数的( )。答:地址311:下列程序段的功能是什么?PUSHAPUSHBPOPAPOPB答:交换A、B的内容312:已知程序执行前有A=02H,SP=52H,(51H)=FFH,(52H)=FFH。下述程序执行后:POPDPHPOPDPLMOVDPTR,#400

8、0HRLAMOVB,AMOVCA,A+DPTRPUSHAMOVA,BINCAMOVCA,A+DPTRPUSHARETORG4000HDB10H,80H,30H,50H,30H,50H请问:A=( ),SP=( ),(51H)=( ),(52H)=( ),PC=( )。答:A=50H , SP=50H , (51H)=30H , (52H)=50H , PC=5030H314:假定A=83H,(R0)=17H,(17H)=34H,执行以下指令:ANLA,#17HORL17H,AXRLA,R0CPLA后,A的内容为( )。答:0CBH315:假定A=55H,R3=0AAH,在执行指令ANLA,R3

9、后,A=( ),R3=( )。答:0、0AAH316:如果DPTR=507BH,SP=32H,(30H)=50H,(31H)=5FH,(32H)=3CH,则执行下列指令后:POPDPHPOPDPLPOPSP则:DPH=( ),DPL=( ),SP=( )答:DPH=3CH , DPL=5FH , SP=4FH317:假定,SP=60H,A=30H,B=70H,执行下列指令:PUSHAPUSHB后,SP的内容为( ),61H单元的内容为( ),62H单元的内容为( )。答:62H , 30H , 70H第四章46:试编写1个程序,将内部RAM中45H单元的高4位清0,低4位置1。答:MOVA,

10、45HANLA, #0FHORLA, #0FHMOV45H, A47:已知程序执行前有A=02H,SP=42H,(41H)=FFH,(42H)=FFH。下述程序执行后:POPDPHPOPDPLMOVDPTR,#3000HRLAMOVB,AMOVCA,A+DPTRPUSHAMOVA,BINCAMOVCA,A+DPTRPUSHARETORG3000HDB10H,80H,30H,80H,50H,80H请问:A=( ),SP=( ),(51H)=( ),(52H)=( ),PC=( )。答:A=80H , SP=40H , (51H)=50H , (52H)=80H , PC=8050H48:计算下面

11、子程序中指令的偏移量和程序执行的时间(晶振频率为 12MHz)。MOVR3,#15H;1个机器周期DL1:MOVR4,#255;1个机器周期DL2:MOVP1,R3;2个机器周期DJNZR4,DL2;2个机器周期DJNZR3,DL1;2个机器周期RET;2个机器周期答:15348us析:(22)25512)151215348us49:假定A=83H,(R0)=17H,(17H)=34H,执行以下指令:ANLA,#17HORL17H,AXRLA,R0CPLA后,A的内容为( )。答:0CBH410:试编写程序,查找在内部RAM的30H50H单元中是否有0AAH这一数据。若有,则将51H单元置为“

12、01H”;若未找到,则将51H单元置为“00H”。答:START:MOVR0,#30HMOVR2,#20HLOOP:MOVA,R0CJNEA,#0AAH,NEXTMOV51H,#01HLJMPEXITNEXT:INCR0DJNZR2,LOOPMOV51H,#00HEXIT:RET411:试编写程序,查找在内部RAM的20H40H单元中出现“00H”这一数据的次数。并将查找到的结果存入41H单元。答:START:MOV41H,#0MOVR0,#20HMOVR2,#20HLOOP:MOVA,R0JNZNEXTINC41HNEXT:INCR0DJNZR2,LOOPRET412:若SP=60H,标号L

13、ABEL所在的地址为3456H。LCALL指令的地址为2000H,执行指令如下:2000HLCALLLABEL后,堆栈指针SP和堆栈内容发生了什么变化?PC的值等于什么?如果将指令LCALL直接换成ACALL是否可以?如果换成ACALL指令,可调用的地址范围是什么?答:1)SP=SP+1=61H(61H)=PC的低字节=03H SP=SP+1=62H(62H)=PC的高字节=20H2)PC=3456H3)可以4)2KB2048 Byte第五章54:外部中断1所对应的中断入口地址为( )H。答:0013H55:下列说法错误的是:A、 各中断发出的中断请求信号,都会标记在MCS51系统的IE寄存器

14、中。B、 各中断发出的中断请求信号,都会标记在MCS51系统的TMOD寄存器中。C、 各中断发出的中断请求信号,都会标记在MCS51系统的IP寄存器中。D、各中断发出的中断请求信号,都会标记在MCS51系统的TCON与SCON寄存器中。答:ABC57:中断查询确认后,在下列各种8031单片机运行情况中,能立即进行响应的是:A、 当前正在执行高优先级中断处理B、 当前正在执行RETI指令C、 当前指令是DIV指令,且正处于取指令的机器周期D、当前指令是MOVA,R3答:D58:8031单片机响应中断后,产生长调用指令LCALL,执行该指令的过程包括:首先把( )的内容压入堆栈,以进行断点保护,然

15、后把长调用指令的16位地址送( ),使程序执行转向( ) 中的中断地址区。答:PC、PC、程序存储器59:编写出外部中断1为跳沿触发的中断初始化程序。答:SETBIT1SETBEX1SETBEA510:在MCS51中,需要外加电路实现中断撤除的是:A、定时中断B、脉冲方式的外部中断C、外部串行中断D、电平方式的外部中断答:D512:下列说法正确的是:A、 同一级别的中断请求按时间的先后顺序响应。B、 同一时间同一级别的多中断请求,将形成阻塞,系统无法响应。C、 低优先级中断请求不能中断高优先级中断请求,但是高优先级中断请求能中断低优先级中断请求。D、同级中断不能嵌套。答:ACD513:中断服务

16、子程序返回指令RETI和普通子程序返回指令RET有什么区别?答:RETI指令在返回的同时清除相应的优先级触发器,以允许下次中断514:某系统有3个外部中断源1、2、3,当某一中断源变为低电平时,便要求CPU进行处理,它们的优先处理次序由高到低依次为3、2、1,中断处理程序的入口地址分别为1000H,1100H,1200H。试编写主程序及中断服务程序(转至相应的中断处理程序的入口即可)。答:若仅在/INT0引脚接3个外部中断源,电路如图510(P115)ORG0000HLJMPMAINORG0003HLJMPINT_EX0ORG0030HMAIN:CLRIT0; 采用低电平有效中断SETBEX0

17、;允许外部中断0SETBEA; 插入用户程序WAIT:MOVPCON,#01H;单片机进入休眠方式等待中断NOPLJMPWAIT;以下为外部中断0服务子程序INT_EX0:JNBP1.0,NEXT1;判断是不是1号中断LJMPINT_IR1;跳转到1号中断处理程序NEXT1:JNBP1.1,NEXT2;判断是不是2号中断LJMPINT_IR2;跳转到2号中断处理程序NEXT2:LJMPINT_IR3;跳转到3号中断处理程序ORG1000HINT_IR1:;插入相应中断处理程序RETI;中断返回ORG1100HINT_IR2:;插入相应中断处理程序RETI;中断返回ORG1200HINT_IR3

18、:;插入相应中断处理程序RETI;中断返回第六章 MCS-51的定时/计数器1 如果采用晶振的频率为3MHz,定时器/计数器工作方式0、1、2下,其最大的定时时间为多少?解答:因为机器周期,所以定时器/计数器工作方式0下,其最大定时时间为;同样可以求得方式1下的最大定时时间为262.144ms;方式2下的最大定时时间为1024ms。2 定时/计数器用作定时器时,其计数脉冲由谁提供?定时时间与哪些因素有关?答:定时/计数器作定时时,其计数脉冲由系统振荡器产生的内部时钟信号12分频后提供。定时时间与时钟频率和定时初值有关。3 定时/计数器用作定时器时,对外界计数频率有何限制?答:由于确认1次负跳变

19、要花2个机器周期,即24个振荡周期,因此外部输入的计数脉冲的最高频率为系统振荡器频率的1/24。4采用定时器/计数器T0对外部脉冲进行计数,每计数100个脉冲后,T0转为定时工作方式。定时1ms后,又转为计数方式,如此循环不止。假定MCS-51单片机的晶体振荡器的频率为6MHz,请使用方式1实现,要求编写出程序。解答:定时器/计数器T0在计数和定时工作完成后,均采用中断方式工作。除了第一次计数工作方式设置在主程序完成外,后面的定时或计数工作方式分别在中断程序完成,用一标志位识别下一轮定时器/计数器T0的工作方式。编写程序如下:ORG0000HLJMPMAINORG000BHLJMPIT0PMA

20、IN:MOVTMOD,#06H;定时器/计数器T0为计数方式2MOVTL0,#156;计数100个脉冲的初值赋值MOVTH0,#156SETBGATE;打开计数门SETBTR0;启动T0,开始计数SETBET0;允许T0中断SETBEA;CPU开中断CLRF0;设置下一轮为定时方式的标志位WAIT:AJMPWAITIT0P:CLREA;关中断JBF0,COUNT;F0=1,转计数方式设置MOVTMOD,#00H;定时器/计数器T0为定时方式0MOVTH0,#0FEH;定时1ms初值赋值MOVTL0,#0CHSETBEARETICOUNT:MOVTMOD,#06HMOVTL0,#156SETBE

21、ARETI5. 定时器/计数器的工作方式2有什么特点?适用于哪些应用场合?答:定时器/计数器的工作方式2具有自动恢复初值的特点,适用于精确定时,比如波特率的产生。6. 编写程序,要求使用T0,采用方式2定时,在P1.0输出周期为400s,占空比为10:1的矩形脉冲。解答:根据题意,从P1.0输出的矩形脉冲的高低电平的时间为10:1,则高低电平的时间分别为363.63s和36.37s。如果系统采用6MHz晶振的话,因此高低电平输出取整,则约为364s和36s。编写程序如下:ORG0000HLJMPMAINORG000BHLJMPIT0PMAIN:MOVTMOD,#02H;定时器/计数器T0为定时

22、方式2MOVTL0,#4AH;定时364s初值赋值SETBTR0;启动T0,开始计数SETBET0;允许T0中断SETBEA;CPU开中断SETBP1.0WAIT:AJMPWAITIT0P:CLREACLRP1.0;关中断MOVR0,#9DLY:DJNZR0,DLY;延时26sMOVTL0,#4AH;定时364s初值赋值SETBP1.0SETBEARETI7. 一个定时器的定时时间有限,如何实现两个定时器的串行定时,来实现较长时间的定时?答:方式一,在第一个定时器的中断程序里关闭本定时器的中断程序,设置和打开另一个定时器;在另一个定时器的中断程序中关闭本定时中断,设置和打开另一个定时器。这种方

23、式的定时时间为两个定时器定时时间的和。方式二,一个作为定时器,在定时中断后产生一个外部计数脉冲(比如由P1.0接INT0产生),另一个定时器工作在计数方式。这样两个定时器的定时时间为一个定时器的定时时间乘以另一个定时器的计数值。8. 当定时器T0用于方式3时,应该如何控制定时器T1的启动和关闭?答:由T1(P3.5)口控制定时器T1的启动和关闭。9. 定时器/计数器测量某正单脉冲的宽度,采用何种方式可得到最大量程?若时钟频率为6MHz,求允许测量的最大脉冲宽度是多少?答:采用方式1定时工作方式。最大脉冲宽度为131.072ms。10. 编写一段程序,功能要求为:当P1.0引脚的电平正跳变时,对

24、P1.1的输入脉冲进行计数;当P1.2引脚的电平负跳变时,停止计数,并将计数值写入R0、R1(高位存R1,低位存R0)。解答:将P1.1的输入脉冲接入INT0,即使用T0计数器完成对P1.1口的脉冲计数。编写程序如下:ORG0000HLJMPMAINORG000BHLJMPIT0PMAIN:JNBP1.0,MAINMOVTMOD,#05H;定时器/计数器T0为计数方式1SETBTR0;启动T0,开始计数SETBET0;允许T0中断SETBEA;CPU开中断WAIT:JBP1.2,WAITCLREACLRTR0MOVR1,TH0MOVR0,TL0AJMP$IT0P:INCR2RETI11. TH

25、X与TLX(X=0,1)是普通寄存器还是计数器?其内容可以随时用指令更改吗?更改后的新值是立即刷新还是等当前计数器计满后才能刷新?答:THX与TLX(X=0,1)是由特殊功能寄存器构成的计数器,其内容可以随时用指令更改,更改后的新值是立即刷新。但在读THX、TLX的值时,应该先读THX值,后读TLX,再读THX。若两次读得THX相同,则可确定读得的内容正确。若前后两次读得的THX有变化,再重复上述过程。12. 判断下列的说法是否正确?(1) 特殊功能寄存器SCON,与定时器/计数器的控制无关。(对)(2) 特殊功能寄存器TCON,与定时器/计数器的控制无关。(错)(3) 特殊功能寄存器IE,与

26、定时器/计数器的控制无关。 (错)(4) 特殊功能寄存器TMOD,与定时器/计数器的控制无关。(错)第七章 MCS-51的串行口1串行数据传送的主要优点和用途是什么?答:串行数据传送的主要优点是硬件接口简单,接口端口少(2个)。主要用于多个单片机系统之间的数据通信。2简述串行口接收和发送数据的过程。答:以方式一为例。发送:数据位由TXT端输出,发送1帧信息为10为,当CPU执行1条数据写发送缓冲器SBUF的指令,就启动发送。发送开始时,内部发送控制信号/SEND变为有效,将起始位想TXD输出,此后,每经过1个TX时钟周期,便产生1个移位脉冲,并由TXD输出1个数据位。8位数据位全部完毕后,置1

27、中断标志位TI,然后/SEND信号失效。接收:当检测到起始位的负跳变时,则开始接收。接受时,定时控制信号有2种,一种是位检测器采样脉冲,它的频率是RX时钟的16倍。也就是在1位数据期间,有16个采样脉冲,以波特率的16倍的速率采样RXD引脚状态,当采样到RXD端从1到0的跳变时就启动检测器,接收的值是3次连续采样,取其中2次相同的值,以确认是否是真正的起始位的开始,这样能较好地消除干扰引起的影响,以保证可靠无误的开始接受数据。3帧格式为1个起始位,8个数据位和1个停止位的异步串行通信方式是方式( 1 )。4 串行口有几种工作方式?有几种帧格式?各种工作方式的波特率如何确定?答:串行口有3种工作

28、方式:方式0、方式1、方式2、方式3;有3种帧格式,方式2和3具有相同的帧格式;方式0的发送和接收都以fosc/12为固定波特率,方式1的波特率=2SMOD/32定时器T1的溢出率方式2的波特率=2SMOD/64fosc方式3的波特率=2SMOD/32定时器T1的溢出率5 假定串行口串行发送的字符格式为1个起始位,8个数据位,1个奇校验位,1个停止位,请画出传送字符“A”的帧格式。 起始位0 1 0 0 0 0 0 0 校验位 停止位 6判断下列说法是否正确:(1) 串行口通信的第9数据位的功能可由用户定义。(对)(2) 发送数据的第9数据位的内容在SCON寄存器的TB8位预先准备好的。(对)

29、(3) 串行通讯发送时,指令把TB8位的状态送入发送SBUF。(错)(4) 串行通讯接收到的第9位数据送SCON寄存器的RB8中保存。(对)(5) 串行口方式1的波特率是可变的,通过定时器/计数器T1的溢出设定。(对)7通过串行口发送或接收数据时,在程序中应使用:(选(3))(1)MOVC指令 (2)MOVX指令 (3)MOV指令 (4)XCHD指令8为什么定时器/计数器T1用做串行口波特率发生器时,采用方式2?若已知时钟频率、通讯波特率,如何计算其初值?解答:因为定时器/计数器在方式2下,初值可以自动重装,这样在做串口波特率发生器设置时,就避免了重装参数的操作。已知时钟频率、通讯波特率,根据

30、公式:,计算出初值。9串行口工作方式1的波特率是:( 3 )(1) 固定的,为。(2) 固定的,为。(3) 可变的,通过定时器/计数器T1的溢出率设定。(4) 固定的,为。10在串行通讯中,收发双方对波特率的设定应该是( 相等 )的。11若晶体振荡器为11.0592MHz,串行口工作于方式1,波特率为4800b/s,写出用T1作为波特率发生器的方式控制字和计数初值。解答:初值计算:查阅P148表7-2可得,FAH控制字:ANL TMOD,#0F0H ORL TMOD,#20H MOV TH1,#0FAH MOV TL1,#0FAH MOV SCON,#40H12简述利用串行口进行多机通讯的原理

31、。解答:参考P146页。13使用8031的串行口按工作方式1进行串行数据通讯,假定波特率为2400b/s,以中断方式传送数据,请编写全双工通讯程序。解答:略14使用8031的串行口按工作方式3进行串行数据通讯,假定波特率为1200b/s,第9数据位作奇偶校验位,以中断方式传送数据,请编写通讯程序。解答:略15某8031串行口,传送数据的帧格式为1个起始位(0),7个数据位,1个偶校验位和1个停止位(1)组成。当该串行口每分钟传送1800个字符时,试计算出波特率。解答:串口每秒钟传送的字符为:1800/60=30个字符/秒 所以波特率为:30个字符/秒10位/个字符=300b/s16为什么MCS

32、-51串行口的方式0帧格式没有起始位(0)和停止位(1)?解答:串行口的方式0为同步移位寄存器输入输出方式,常用于外接移位寄存器,以扩展并行I/O口,一般不用于两个MCS-51之间的串行通信。该方式以fosc/12的固定波特率从低为位到高位发送或接受数据。第八章习题解答1.单片机存储器的主要功能是存储(程序)和(数据)。2.试编写一个程序(例如将05H和06H拼为56H),设原始数据放在片外数据区2001H单元和2002H单元中,按顺序拼装后的单字节数放入2002H。解:本题主要考察了对外部存储器的读、写操作,同学们只要记住正确使用MOVX指令就可以了。编程思路:首先读取2001H的值,保存在

33、寄存器A中,将寄存器A的高四位和低四位互换,再屏蔽掉低四位然后将寄存器A的值保存到30H中,然后再读取2002H的值,保存在寄存器A中,屏蔽掉高四位,然后将寄存器A的值与30H进行或运算,将运算后的结果保存在2002H中。ORG0000HMAIN:MOVDPTR,#2001H;设置数据指针的初值MOVXA,DPTR;读取2001H的值SWAPAANLA,#0F0H;屏蔽掉低四位MOV30H,A;保存AINCDPTR;指针指向下一个MOVXA,DPTR;读取2002H的值ANLA,#0FH;屏蔽掉高四位ORLA,30H;进行拼装MOVXDPTR,A;保存到2002HEND3.假设外部数据存储器2

34、000H单元的内容为80H,执行下列指令后:MOVP2,#20HMOVR0,#00HMOVXA,R0累加器A中的内容为(80H)。4.编写程序,将外部数据存储器中的4000H40FFH单元全部清零。解:本题主要考察了对外部数据块的写操作;编程时只要注意循环次数和MOVX指令的使用就可以了。ORG0000HMAIN:MOVA,#0;送预置数给AMOVR0,#0FFH;设置循环次数MOVDPTR,#4000H;设置数据指针的初值LOOP:MOVXDPTR,A;当前单元清零INCDPTR;指向下一个单元DJNZR0,LOOP;是否结束END5.在MCS-51单片机系统中,外接程序存储器和数据存储器共

35、16位地址线和8位数据线,为何不会发生冲突?解:因为控制信号线的不同:外扩的RAM芯片既能读出又能写入,所以通常都有读写控制引脚,记为OE和WE。外扩RAM的读、写控制引脚分别与MCS-51的RD和WR引脚相连。外扩的EPROM在正常使用中只能读出,不能写入,故EPROM芯片没有写入控制引脚,只有读出引脚,记为OE,该引脚与MCS-51单片机的PSEN相连。6.区分MCS-51单片机片外程序存储器和片外数据存储器的最可靠的方法是:(1)看其位于地址范围的低端还是高段(2)看其离MCS-51芯片的远近(3)看其芯片的型号是ROM还是RAM(4)看其是与RD信号连接还是与PSEN信号连接解:本题的

36、答案是3,4。7.在存储器扩展中,无论是线选法还是译码法,最终都是为了扩展芯片的(片选)端提供信号。8.请写出图8-18中4片程序存储器27128各自所占的地址空间。解:图中采用了译码法。4片地址分别为0000H-3FFFH、4000H-7FFFH、8000H-BFFFH、C000H-FFFFH。9起止范围为0000H-3FFFH的存储器的容量是(16)KB。解:本题属于常识题,在第十一题时将有解答。10.在MCS-51中,PC和DPTR都用于提供地址,但PC是为了访问(程序)存储器提供地址,而DPTR是为访问(数据)存储器提供地址。11.11根地址线可选(2KB)个存储单元,16KB存储单元

37、需要(14)根地址线。解:通过总结所学知识,我们得到以下几个信息:2KB的存储器需要11根地址线,地址为0000H-07FFH;4KB的存储器需要12根地址线,地址为0000H-0FFFH;8KB的存储器需要13根地址线,地址为0000H-1FFFH;16KB的存储器需要14根地址线,地址为0000H-3FFFH;32KB的存储器需要15根地址线,地址为0000H-7FFFH;64KB的存储器需要16根地址线,地址为0000H-FFFFH(以上存储器的首地址均默认为0000H)。12.32KB RAM存储器的首地址若为2000H,则末地址为(9FFF)H。解:由上题总结得出,32KB RAM存

38、储器的大小为0000H-7FFFH,所以只要在后面加上2000H即得到正确答案。13.现有8031单片机、74LS373锁存器、1片2764EPROM和2片6116RAM,请使用他们组成一个单片机系统,要求:(1)画出硬件电路连线图,并标注主要引脚;(2)指出该应用系统程序存储器空间和数据存储器空间各自的地址范围。解:(1)电路图如下所示:(2)2764的地址为C000H-DFFFH;第一个6116的地址为A000H-A7FFH;第二个6116的地址为6000H-67FFH;事实上,由于采用的是线选法,导致了地址不连续,地址空间利用不充分。建议在实际工作中要具体情况具体分析。在两种地址分配中选

39、一种较好的来应用。14.使用89C51芯片外扩一片E2PROM2864,要求2864兼作程序存储器和数据存储器,且首地址为8000H。要求:(1)确定2864芯片的末地址;(2)画出2864片选端的地址译码电路;(3)画出该应用系统的硬件连接图。解:(1)2864为8KB的存储器,如果首地址为8000H,则其末地址为9FFFH,理由参考第12题;(2)电路图如下所示:(3)电路图如下所示:第九章习题解答1.I/O接口和I/O端口有什么区别?I/O接口的功能是什么?解:I/O端口简称I/O口,常指I/O接口电路中具有端口地址的寄存器或缓冲器。I/O接口是指单片机与外设间的I/O接口芯片。I/O接

40、口功能:一.实现和不同外设的速度匹配;二.输出数据缓存;三.输入数据三态缓冲。2.常用的I/O接口编址有哪两种方式?它们各有什么特点?MCS-51的I/O端口编址采用的是哪种方式?解:一.独立编址方式:独立编址方式就是I/O地址空间和存储器地址空间分开编址。独立编址的优点是I/O地址空间和存储器地址空间相互独立,界限分明。但是,却需要设置一套专门的读写I/O的指令和控制信号。二.统一编址方式:这种编址方式是把I/O端口的寄存器与数据存储器单元同等对待,统一进行编址。统一编址的优点是不需要专门的I/O指令,直接使用访问数据存储器的指令进行I/O操作,简单、方便且功能强大。MCS-51单片机使用的

41、是I/O和外部数据存储器RAM统一编址的方式。3.I/O数据传送有哪几种传送方式?分别在哪些场合下使用?解:一.同步传送方式:同步传送又称为有条件传送。当外设速度可与单片机速度相比拟时,常常采用同步传送方式,最典型的同步传送就是单片机和外部数据存储器之间的数据传送。二.查询传送方式:查询传送方式又称为有条件传送,也称异步传送。单片机通过查询得知外设准备好后,再进行数据传送。异步传送的优点是通用性好,硬件连线和查询程序十分简单,但是效率不高。为了提高单片机的工作效率,通常采用中断方式。三.中断传送方式:中断传送方式是利用MCS-51本身的中断功能和I/O接口的中断功能来实现I./O数据的传送。单

42、片机只有在外设准备好后,发出数据传送请求,才中断主程序,而进入与外设进行数据传送的中断服务程序,进行数据的传送。中断服务完成后又返回主程序继续执行。因此,采用中断方式可以大大提高单片机的工作效率。4.编写程序,采用8255A的C口按位置位/复位控制字,将PC7置0,PC4置1,(已知8255A各端口的地址为7FFCH-7FFFH)。解:本题主要考察对8255A的C口的操作。其方式控制字的高位为0时,低四位对C口进行置位。由题目我们得到了方式控制字的地址为7FFFH。ORG0000HMAIN:MOVDPTR,#7FFFH;控制字寄存器地址送DPTRMOVA,#0EH;将PC7置0MOVXDPTR

43、,AMOVA,#09H;将PC4置1MOVXDPTR,AEND5.8255A的方式控制字和C口按位置位/复位控制字都可以写入8255A的同一控制寄存器,8255A是如何区分这两个控制字的?解:8255A通过它们的最高位来进行判断,最高位为1时,这时8255A认为这是方式控制字,否则认为是C口按位置位/复位控制字6.由图9-6来说明8255A的A口在方式1的选通输入方式下的工作过程。解:当外设输入一个数据并送到PA7PA0上时,输入设备自动在选通输入线STBA向8255A发送一个低电平选通信号。8255A收到选通信号后:首先把PA7-PA0上输入的数据存入A口的输入数据缓冲/锁存器;然后使输入缓

44、冲器输出线IBFA变成高电平,以通知输入设备,8255A的A口已收到它送来的输入数据。8255A检测到联络线STBA由低电平变成了高电平、IBFA为1状态和中断允许触发器INTEA为1时,使输出线INTRA(PC3)变成高电平,向8031发出中断请求。(INTEA的状态可由用户通过对PC4的置位/复位来控制。8031相应中断后,可以通过中断服务程序从A口的输入数据缓冲/锁存器读取外设发来的输入数据。当输入数据被CPU读走后,8255A撤销INTRA上的中断请求,并使IBFA变为低电平,以通知输入外设可以送下一个输入数据。7.8155H的端口都有哪些?哪些引脚决定端口的地址?引脚TIMERIN和

45、TIMEROUT的作用是什么?解:8155H的端口有以下几种:命令/状态寄存器、A口、B口、C口、计数器和RAM单元。引脚IO/M、A2、A1、A0决定端口地址。TIMERIN是计数器输入线,输入的脉冲上跳沿用于对8155H片内的14位计数器减一。TIMEROUT为计数器输入线。当14位计数器减为0时就可以在该引线上输出脉冲或方波,输出的信号的形状与所选的计数器工作方式有关。8.判断下列说法是否正确,为什么?(1)由于8155H不具有地址锁存功能,因此在与8031的接口电路中必须加地址锁存器。(2)在8155H芯片中,决定端口和RAM单元编址的信号线是AD7-AD0和WR。(3)8255A具有

46、三态缓冲器,因此可以直接挂在系统的数据总线上。(4)8255A的B口可以设置成方式2。解:(1)8155H具有地址锁存功能;(2)引脚IO/M、A2、A1、A0决定端口地址和RAM单元编址;(3)8255A不具有三态缓冲器;(4)8255A的B口只可以设置成方式0和方式1。9.现有一片8031,扩展了一片8255A,若把8255A的B口用做输入,B口的每一位接一个开关,A口用作输出,每一位接一个发光二极管,请画出电路原理图,并编写出B口某一位接高电平时,A口相应位发光二极管被点亮的程序。解:由于电路图比较简单,在这里就画了,大家可以参考图9-10,A口每一位接二极管的正极,二极管的负极接低。B

47、口每一位接一开关,开关直接接地。这样我们只需要将读到的B口的值送给A口就可以满足题目要求了。ORG0000HMIAN:MOVA,#10000010B;A口出,B口入MOVDPTR,#0FF7FH;控制地址送DPTRMOVXDPTR,A;送方式控制字MOVDPTR,#0FF7DH;B口地址送DPTRMOVXA,DPTR;读开关信息MOVDPTR,#0FF7CH;A口地址送DPTRMOVXDPTR,A;将信息反溃到二极管END10.假设8155H的TIMERIN引脚输入的频率为4MHz?问8155H的最大定时时间是多少?解:8155H记数器的初值范围是:3FFFH-2H。当频率为4MHz,初值为3

48、FFFH时,最大定时时间为:16383/4E+6=0.00409575S11.MCS-51的并行接口的扩展有多种方式,在什么情况下,采用扩展8155H比较合适?什么情况下,采用扩展8255A比较适合?解:8255A具有3个8位的并行I/O口,3种工作方式,可通过编程改变其功能,因而使用灵活方便,通用性强,可作为单片机与多种外围设备连接时的中间接口电路。8155H芯片内包含有256B的RAM存储器(静态),2个可编程的八位并行口PA和PB,1个可编程的6位并行口PC,以及1个14位减法定时器/计数器。所以它经常用于单片机的外围接口芯片。12.假设8155H的TIMERIN引脚输入的脉冲频率为1M

49、Hz,请编写出在8155H的TIMEROUT引脚上输出周期为10ms的方波的程序。解:将1MHz的脉冲改变为10ms的方波,这就让我们想到了在数字电路里面学到的分频器。计算得出分频前后频率之比为10000:1,这样我们只要将定时器初值设置为64H就可以了。(假设I/O口地址为7F00H-7F05H)START:MOVDPTR,#7F04H;指针指向定时器低8位MOVA,#64H;送初值给AMOVXDPTR,A;初值送给低8位INCDPTR;指向高8位MOVA,#40H;定时器方波输出MOVXDPTE,AMOVDPTR,#7F00H;指向命令/状态口MOVA,#0C2H;设定控制字MOVXDPT

50、E,A;启动定时器END第十章习题解答1.为什么要消除按键的机械抖动?消除按键的机械抖动的方法有哪几种?原理是什么?解:在按键的闭合和断开过程中,由于开关的机械特性,导致了按键抖动的产生。如果不消除按键的机械抖动,按键的状态读取将有可能出现错误。消除按键抖动一般是采用软件或硬件去抖。软件去抖的原理:在第一次检测到有键按下时,该键所对应的航线是为低电平,执行一端延时10ms的子程序后,确认该行线电平是否仍然为低电平,如果仍为低电平,则确认为该行确实有键按下。2.判断下列说法是否正确?(1)8279是一个用于键盘和LED(LCD)显示器的专用芯片。(2)在单片机与微型打印机的接口中,打印机的BUSY信号可作为查询信号或中断请求信号使用。(3)为给以扫描发方式工作的8*8键盘提供接口电路,在接口电路中只需要提供2个输入口和1个输出口。(4)LED的字型码是固定不变的。解:(1)正确;(2)正确(3)错误(4)错误3.LED的静态显

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论