1、单片机原理及应用习题答案第一章13:单片机与普通计算机的不同之处在于其将( )( )和( )三部分集成于一块芯片上。答:CPU、存储器、I/O口18:8051与8751的区别是: A、内部数据存储但也数目的不同 B、内部数据存储器的类型不同 C、内部程序存储器的类型不同 D、内部的寄存器的数目不同答:C第二章24:在MCS51单片机中,如果采用6MHz晶振,1个机器周期为( )。答:2us。析:机器周期为振荡周期的1/6。26:内部RAM中,位地址为30H的位,该位所在字节的字节地址为( )。答:26H27:若A中的内容为63H,那么,P标志位的值为( )。答:0析:P为偶校验位,因为A中1的
2、个数为偶数,所以P=0。28:判断下列说法是否正确: A、8031的CPU是由RAM和EPROM所组成。B、区分片外程序存储器和片外数据存储器的最可靠的方法是看其位于地址范围的低端还是高端。C、在MCS-51中,为使准双向的I/O口工作在输入方式,必须保证它被事先预置为1。D、PC可以看成使程序存储器的地址指针。答:错、错、对、对29:8031单片机复位后,R4所对应的存储单元的地址为( ),因上电时PSW=( )。这时当前的工作寄存器区是( )组工作寄存器区。答:04H、00H、0211:判断以下有关PC和DPTR的结论是否正确? A、DPTR是可以访问的,而PC不能访问。 B、它们都是16
3、位的存储器 C、它们都有加1的功能。 D、DPTR可以分为两个8位的寄存器使用,但PC不能。答:对、对、对、对213:使用8031芯片时,需将/EA引脚接( )电平,因为其片内无( )存储器。答:低、程序214:片内RAM低128个单元划分为哪3个主要部分?各部分的主要功能是什么?答:工作寄存器区、位寻址区、数据缓冲区215:判断下列说法是否正确A、 程序计数器PC不能为用户编程时直接使用,因为它没有地址。B、 内部RAM的位寻址区,只能供位寻址使用,而不能供字节寻址使用。C、 8031共有21个特殊功能寄存器,它们的位都是可以用软件设置的,因此,是可以进行位寻址的。答:对、错、错216:PC
4、的值是 A、当前正在执行指令的前一条指令的地址 B、当前正在执行指令的地址 C、当前正在执行指令的下一条指令的地址 D、控制器中指令寄存器的地址答:C217:通过堆栈操作实现子程序调用,首先就要把( )的内容入栈,以进行断点保护。调用返回时,再进行出栈保护,把保护的断点送回到( )。答:PC、PC219:MCS51单片机程序存储器的寻址范围是由程序计数器PC的位数所决定的,因为MCS51的PC是16位的,因此其寻址的范围为( )KB。答:64220:当MCS51单片机运行出错或程序陷入死循环时,如何来摆脱困境?答:软件陷阱、复位221:判断下列说法是否正确?A、 PC是1个不可寻址的特殊功能寄
5、存器。B、 单片机的主频越高,其运算速度越快。C、 在MCS51单片机中,1个机器周期等于1us。D、 特殊功能寄存器SP内装的是栈顶首地址单元的内容。答:错、对、错、错第三章31:判断下列指令的正误: 1)MOV 28H,R2 2)DEC DPTR 3)INC DPTR 4)CLR R0 5)CPL R5 6)MOV R0,R1 7)PUSH DPTR 8)MOV F0,C 9)MOV F0,ACC.3 10)MOVX A,R1 11)MOV C,30H 12)RLC R0答:错、错、对、错 错、错、错、对 错、对、对、错32:判断下列说法是否正确。A、 立即寻址方式是被操作的数据本身在指令
6、中,而不是它的地址在指令中。B、 指令周期是执行一条指令的时间。C、 指令中直接给出的操作数称为直接寻址。答:对、对、错33:在基址加变址寻址方式中,以( )作变址寄存器,以( )或( )作基址寄存器。答:累加器A,DPTR、PC37:指令格式是由( )和( )所组成,也可能仅由( )组成。答:操作码、操作数、操作码38:假定累加器A中的内容为30H,执行指令 1000H:MOVC A,A+PC 后,把程序存储器( )单元的内容送入累加器A中。答:1031H39:在MCS51中,PC和DPTR都用于提供地址,但PC是为访问( )存储器提供地址,而DPTR是为访问( )存储器提供地址。答:程序、
7、数据310:在寄存器间接寻址方式中,其“间接”体现在指令中寄存器的内容不是操作数,而是操作数的( )。答:地址311:下列程序段的功能是什么? PUSH A PUSH B POP A POP B答:交换A、B的内容312:已知程序执行前有A=02H,SP=52H,(51H)=FFH,(52H)=FFH。下述程序执行后: POP DPH POP DPL MOV DPTR,#4000H RL A MOV B,A MOVC A,A+DPTR PUSH A MOV A,B INC A MOVC A,A+DPTR PUSH A RET ORG 4000H DB 10H,80H,30H,50H,30H,5
8、0H 请问:A=( ),SP=( ),(51H)=( ),(52H)=( ),PC=( )。答:A=50H , SP=50H , (51H)=30H , (52H)=50H , PC=5030H314:假定A=83H,(R0)=17H,(17H)=34H,执行以下指令: ANL A,#17H ORL 17H,A XRL A,R0 CPL A 后,A的内容为( )。答:0CBH315:假定A=55H,R3=0AAH,在执行指令ANL A,R3后,A=( ),R3=( )。答:0、0AAH316:如果DPTR=507BH,SP=32H,(30H)=50H,(31H)=5FH,(32H)=3CH,则
9、执行下列指令后: POP DPH POP DPL POP SP 则:DPH=( ),DPL=( ),SP=( )答:DPH=3CH , DPL=5FH , SP=4FH317:假定,SP=60H,A=30H,B=70H,执行下列指令: PUSH A PUSH B 后,SP的内容为( ),61H单元的内容为( ),62H单元的内容为( )。答:62H , 30H , 70H第四章46:试编写1个程序,将内部RAM中45H单元的高4位清0,低4位置1。答:MOV A, 45H ANL A, #0FH ORL A, #0FH MOV 45H, A47:已知程序执行前有A=02H,SP=42H,(41
10、H)=FFH,(42H)=FFH。下述程序执行后: POP DPH POP DPL MOV DPTR,#3000H RL A MOV B,A MOVC A,A+DPTR PUSH A MOV A,B INC A MOVC A,A+DPTR PUSH A RET ORG 3000H DB 10H,80H,30H,80H,50H,80H 请问:A=( ),SP=( ),(51H)=( ),(52H)=( ),PC=( )。答:A=80H , SP=40H , (51H)=50H , (52H)=80H , PC=8050H48:计算下面子程序中指令的偏移量和程序执行的时间(晶振频率为 12MHz)
11、。 MOV R3,#15H ;1个机器周期 DL1:MOV R4,#255 ;1个机器周期 DL2:MOV P1,R3 ;2个机器周期 DJNZ R4,DL2 ;2个机器周期 DJNZ R3,DL1 ;2个机器周期 RET ;2个机器周期答:15348us析:(22)25512)151215348us49:假定A=83H,(R0)=17H,(17H)=34H,执行以下指令: ANL A,#17H ORL 17H,A XRL A,R0 CPL A 后,A的内容为( )。答:0CBH410:试编写程序,查找在内部RAM的30H50H单元中是否有0AAH这一数据。若有,则将51H单元置为“01H”;
12、若未找到,则将51H单元置为“00H”。答:START: MOV R0,#30H MOV R2,#20H LOOP: MOV A,R0 CJNE A,#0AAH,NEXT MOV 51H,#01H LJMP EXIT NEXT: INC R0 DJNZ R2,LOOP MOV 51H,#00H EXIT: RET411:试编写程序,查找在内部RAM的20H40H单元中出现“00H”这一数据的次数。并将查找到的结果存入41H单元。答:START: MOV 41H,#0 MOV R0,#20H MOV R2,#20H LOOP: MOV A,R0 JNZ NEXT INC 41H NEXT: IN
13、C R0 DJNZ R2,LOOP RET412:若SP=60H,标号LABEL所在的地址为3456H。LCALL指令的地址为2000H,执行指令如下: 2000H LCALL LABEL 后,堆栈指针SP和堆栈内容发生了什么变化?PC的值等于什么?如果将指令LCALL 直接换成ACALL是否可以?如果换成ACALL指令,可调用的地址范围是什么?答:1)SP=SP+1=61H (61H)=PC的低字节=03H SP=SP+1=62H (62H)=PC的高字节=20H 2)PC=3456H 3)可以 4)2KB2048 Byte第五章54:外部中断1所对应的中断入口地址为( )H。答:0013H
14、55:下列说法错误的是:A、 各中断发出的中断请求信号,都会标记在MCS51系统的IE寄存器中。B、 各中断发出的中断请求信号,都会标记在MCS51系统的TMOD寄存器中。C、 各中断发出的中断请求信号,都会标记在MCS51系统的IP寄存器中。D、 各中断发出的中断请求信号,都会标记在MCS51系统的TCON与SCON寄存器中。答:ABC57:中断查询确认后,在下列各种8031单片机运行情况中,能立即进行响应的是:A、 当前正在执行高优先级中断处理B、 当前正在执行RETI指令C、 当前指令是DIV指令,且正处于取指令的机器周期D、 当前指令是MOV A,R3答:D58:8031单片机响应中断
15、后,产生长调用指令LCALL,执行该指令的过程包括:首先把( )的内容压入堆栈,以进行断点保护,然后把长调用指令的16位地址送( ),使程序执行转向( ) 中的中断地址区。答:PC、PC、程序存储器59:编写出外部中断1为跳沿触发的中断初始化程序。 答:SETB IT1 SETB EX1 SETB EA510:在MCS51中,需要外加电路实现中断撤除的是: A、定时中断 B、脉冲方式的外部中断 C、外部串行中断 D、电平方式的外部中断 答:D512:下列说法正确的是:A、 同一级别的中断请求按时间的先后顺序响应。B、 同一时间同一级别的多中断请求,将形成阻塞,系统无法响应。C、 低优先级中断请
16、求不能中断高优先级中断请求,但是高优先级中断请求能中断低优先级中断请求。D、 同级中断不能嵌套。答:ACD514:某系统有3个外部中断源1、2、3,当某一中断源变为低电平时,便要求CPU进行处理,它们的优先处理次序由高到低依次为3、2、1,中断处理程序的入口地址分别为1000H,1100H,1200H。试编写主程序及中断服务程序(转至相应的中断处理程序的入口即可)。答:若仅在/INT0引脚接3个外部中断源,电路如图510(P115) ORG 0000H LJMP MAIN ORG 0003H LJMP INT_EX0 ORG 0030HMAIN: CLR IT0 ; 采用低电平有效中断 SET
17、B EX0 ;允许外部中断0 SETB EA ; 插入用户程序WAIT: MOV PCON,#01H ;单片机进入休眠方式等待中断 NOP LJMP WAIT;以下为外部中断0服务子程序INT_EX0:JNB P1.0,NEXT1 ;判断是不是1号中断 LJMP INT_IR1 ;跳转到1号中断处理程序NEXT1: JNB P1.1,NEXT2 ;判断是不是2号中断 LJMP INT_IR2 ;跳转到2号中断处理程序NEXT2: LJMP INT_IR3 ;跳转到3号中断处理程序 ORG 1000HINT_IR1: ;插入相应中断处理程序 RETI ;中断返回 ORG 1100HINT_IR2
18、: ;插入相应中断处理程序 RETI ;中断返回 ORG 1200HINT_IR3: ;插入相应中断处理程序 RETI ;中断返回第六章 MCS-51的定时/计数器1 如果采用晶振的频率为3MHz,定时器/计数器工作方式0、1、2下,其最大的定时时间为多少?解答:因为机器周期,所以定时器/计数器工作方式0下,其最大定时时间为;同样可以求得方式1下的最大定时时间为262.144ms;方式2下的最大定时时间为1024ms。2 定时/计数器用作定时器时,其计数脉冲由谁提供?定时时间与哪些因素有关?答:定时/计数器作定时时,其计数脉冲由系统振荡器产生的内部时钟信号12分频后提供。定时时间与时钟频率和定
19、时初值有关。3 定时/计数器用作定时器时,对外界计数频率有何限制?答:由于确认1次负跳变要花2个机器周期,即24个振荡周期,因此外部输入的计数脉冲的最高频率为系统振荡器频率的1/24。4采用定时器/计数器T0对外部脉冲进行计数,每计数100个脉冲后,T0转为定时工作方式。定时1ms后,又转为计数方式,如此循环不止。假定MCS-51单片机的晶体振荡器的频率为6MHz,请使用方式1实现,要求编写出程序。解答:定时器/计数器T0在计数和定时工作完成后,均采用中断方式工作。除了第一次计数工作方式设置在主程序完成外,后面的定时或计数工作方式分别在中断程序完成,用一标志位识别下一轮定时器/计数器T0的工作
20、方式。编写程序如下: ORG 0000H LJMP MAIN ORG 000BH LJMP IT0PMAIN: MOV TMOD,#06H ;定时器/计数器T0为计数方式2 MOV TL0,#156 ;计数100个脉冲的初值赋值 MOV TH0,#156 SETB GATE ;打开计数门 SETB TR0 ;启动T0,开始计数 SETB ET0 ;允许T0中断 SETB EA ;CPU开中断 CLR F0 ;设置下一轮为定时方式的标志位WAIT: AJMP WAITIT0P: CLR EA ;关中断 JB F0,COUNT ;F0=1,转计数方式设置 MOV TMOD,#00H ;定时器/计数
21、器T0为定时方式0 MOV TH0,#0FEH ;定时1ms初值赋值 MOV TL0,#0CH SETB EA RETICOUNT: MOV TMOD,#06H MOV TL0,#156 SETB EA RETI5. 定时器/计数器的工作方式2有什么特点?适用于哪些应用场合?答:定时器/计数器的工作方式2具有自动恢复初值的特点,适用于精确定时,比如波特率的产生。6. 编写程序,要求使用T0,采用方式2定时,在P1.0输出周期为400s,占空比为10:1的矩形脉冲。解答:根据题意,从P1.0输出的矩形脉冲的高低电平的时间为10:1,则高低电平的时间分别为363.63s和36.37s。如果系统采用
22、6MHz晶振的话,因此高低电平输出取整,则约为364s和36s。编写程序如下:ORG 0000H LJMP MAIN ORG 000BH LJMP IT0PMAIN: MOV TMOD,#02H ;定时器/计数器T0为定时方式2 MOV TL0,#4AH ;定时364s初值赋值 SETB TR0 ;启动T0,开始计数 SETB ET0 ;允许T0中断 SETB EA ;CPU开中断 SETB P1.0WAIT: AJMP WAITIT0P: CLR EACLR P1.0 ;关中断 MOV R0,#9DLY: DJNZ R0,DLY ;延时26s MOV TL0,#4AH ;定时364s初值赋值
23、 SETB P1.0 SETB EA RETI9. 定时器/计数器测量某正单脉冲的宽度,采用何种方式可得到最大量程?若时钟频率为6MHz,求允许测量的最大脉冲宽度是多少?答:采用方式1定时工作方式。最大脉冲宽度为131.072ms。10. 编写一段程序,功能要求为:当P1.0引脚的电平正跳变时,对P1.1的输入脉冲进行计数;当P1.2引脚的电平负跳变时,停止计数,并将计数值写入R0、R1(高位存R1,低位存R0)。解答:将P1.1的输入脉冲接入INT0,即使用T0计数器完成对P1.1口的脉冲计数。编写程序如下:ORG 0000H LJMP MAIN ORG 000BH LJMP IT0PMAI
24、N: JNB P1.0,MAINMOV TMOD,#05H ;定时器/计数器T0为计数方式1 SETB TR0 ;启动T0,开始计数 SETB ET0 ;允许T0中断 SETB EA ;CPU开中断WAIT: JB P1.2,WAIT CLR EA CLR TR0 MOV R1,TH0 MOV R0,TL0 AJMP $IT0P: INC R2 RETI12. 判断下列的说法是否正确?(1) 特殊功能寄存器SCON,与定时器/计数器的控制无关。(对)(2) 特殊功能寄存器TCON,与定时器/计数器的控制无关。(错)(3) 特殊功能寄存器IE,与定时器/计数器的控制无关。 (错)(4) 特殊功能
25、寄存器TMOD,与定时器/计数器的控制无关。(错)第七章 MCS-51的串行口2简述串行口接收和发送数据的过程。答:以方式一为例。发送:数据位由TXT端输出,发送1帧信息为10为,当CPU执行1条数据写发送缓冲器SBUF的指令,就启动发送。发送开始时,内部发送控制信号/SEND变为有效,将起始位想TXD输出,此后,每经过1个TX时钟周期,便产生1个移位脉冲,并由TXD输出1个数据位。8位数据位全部完毕后,置1中断标志位TI,然后/SEND信号失效。接收:当检测到起始位的负跳变时,则开始接收。接受时,定时控制信号有2种,一种是位检测器采样脉冲,它的频率是RX时钟的16倍。也就是在1位数据期间,有
26、16个采样脉冲,以波特率的16倍的速率采样RXD引脚状态,当采样到RXD端从1到0的跳变时就启动检测器,接收的值是3次连续采样,取其中2次相同的值,以确认是否是真正的起始位的开始,这样能较好地消除干扰引起的影响,以保证可靠无误的开始接受数据。3帧格式为1个起始位,8个数据位和1个停止位的异步串行通信方式是方式( 1 )。4 串行口有几种工作方式?有几种帧格式?各种工作方式的波特率如何确定?答:串行口有3种工作方式:方式0、方式1、方式2、方式3;有3种帧格式,方式2和3具有相同的帧格式;方式0的发送和接收都以fosc/12为固定波特率,方式1的波特率=2SMOD/32定时器T1的溢出率方式2的
27、波特率=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位预先准备好的。(对)(3) 串行通讯发送时,指令把TB8位的状态送入发送SBUF。(错)(4) 串行通讯接收到的第9位数据送SCON寄存器的RB8中保存。(对)(5) 串行口方式1的波特率是可变的,通过定时器
28、/计数器T1的溢出设定。(对)7通过串行口发送或接收数据时,在程序中应使用:(选(3))(1)MOVC指令 (2)MOVX指令 (3)MOV指令 (4)XCHD指令8为什么定时器/计数器T1用做串行口波特率发生器时,采用方式2?若已知时钟频率、通讯波特率,如何计算其初值?解答:因为定时器/计数器在方式2下,初值可以自动重装,这样在做串口波特率发生器设置时,就避免了重装参数的操作。已知时钟频率、通讯波特率,根据公式:,计算出初值。9串行口工作方式1的波特率是:( 3 )(1) 固定的,为。(2) 固定的,为。(3) 可变的,通过定时器/计数器T1的溢出率设定。(4) 固定的,为。10在串行通讯中
29、,收发双方对波特率的设定应该是( 相等 )的。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简述利用串行口进行多机通讯的原理。解答:参考P146页。15某8031串行口,传送数据的帧格式为1个起始位(0),7个数据位,1个偶校验位和1个停止位(1)组成。当该串行口每分钟传送1800个字符时,试计算出波特率。解答:串口每秒钟传送的字符为:1800/60=30个字符/秒 所以波特率为:30个字符/秒10位/个字符=300b/s16为什么MCS-51串行口的方式0帧格式没有起始位(0)和停止位(1)?解答:串行口的
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1