新编单片机原理与应用课后答案Word文件下载.docx
《新编单片机原理与应用课后答案Word文件下载.docx》由会员分享,可在线阅读,更多相关《新编单片机原理与应用课后答案Word文件下载.docx(28页珍藏版)》请在冰豆网上搜索。
对于双操作数指令来说,为什么不需要指定操作结果存放位置?
【1】确定指令中操作数所在存储单元地址的方式
【2】在现代计算机系统中,对于双操作数指令,一般将指令执行后的结果放在第一个操作数(即目标操作数),这样可以减少指令码的长度
1-12、指出下列指令中每一操作数的寻址方式?
【1】目标操作数为寄存器寻址,源操作数为立即数寻址
【2】目标操作数为直接寻址,源操作数为寄存器寻址
【3】目标操作数为直接寻址,源操作数为直接寻址
【4】目标操作数为直接寻址,源操作数为寄存器间接寻址
【5】寄存器寻址注:
在单片机中,问到指令的寻址方式,既要答目标操作数的寻址方式,也要答源操作数的寻址方式,这与微机不同,请切记!
1-13、单片机的主要用途是什么?
新一代8位单片机芯片具有哪些主要技术特征?
列举目前应用较为广泛的8位、32位单片机品种。
【1】数值计算,能实时监测系统的输入量,控制系统的输出量,从而实现自动控制功能,主要面向工业控制等
【2】可参考23页
【3】可参考21~22页
习题二参考答案
2-180C54、80C32、87C54、89C54CPU有什么不同?
在由80C32芯片组成的应用系统中引脚是如何连接的?
为什么要这样连接?
略
2-28XC5X,如89C52单片机内部含有哪几类存储器?
各自的容量分别是多少?
包括程序存储器8K和数据存储器256B。
2-38XC5X系列CPU共有多少根I/O引脚?
在什么情况下,不能将P0口作为通常意义上的输入/输出引脚使用?
共有I/O引脚32根;
在P0作为地址数据总线端口使用时就不能作为普通I/O口使
用。
2-4简述P1口的内部结构。
为什么将P1口引脚作为输入引脚使用前,一定要向P1
口锁存器相应位写入“1?
主要由两个三态门、一个D型锁存器、一个MOS管和一个上拉电阻构成;
P1作为输入引脚使用时一定要先写入“1”,其目的是使内部MOS管处于截止状态,避免MOS管对输入信号构成影响。
2-5根据8XC5X系列CPUP1〜P3口结构,如果用P1.X引脚驱动NPN三极管,则最大集电极电流ICMAX为多少?
(假设B取100)。
假设内部上拉电阻的阻值为20K,三极管发射结正向导通电压为0.7V,则:
基极电流:
|B50.7V0.215mA
B20K
集电极电流:
lcIB100*0.215mA21.5mA
2-6地址/数据分时复用的含义是什么?
8XC5XP0口与存储器,如62256相连时,两者之间需要接什么功能的芯片,才能锁存低8位地址信息?
试画出8XC5X与SRAM62256芯片(作数据存储器使用)之间的连接图。
地址/数据分时复用是指总线既可作为数据线,也可作为地址线,但是具体到某一时刻只能作为数据线或者地址线;
与62256相连时,在存储芯片和单片机芯片之间必须加锁
存芯片,如74LS373等,用来锁存低8位地址信息;
连接电路图(见课本,略)
2-78XC5X单片机CPU复位后,使用了哪一工作寄存器区?
其中R1对应的物理存储单元地址是什么?
8XC5X单片机CPU复位后,使用了工作寄存器区0;
此时R1对应的物理存储单
元的地址为01H。
2-8如果希望工作寄存器组中R0对应的物理存储单元为10H,请写出系统复位后,实现这一要求的指令。
答:
SETBCS1
CLRCS0
2-9说出访问下列寄存器或存储空间可以使用的寻址方式,并举例:
(1)8XC5X系列内部RAM前128字节。
直接和寄存器间接寻址。
(2)8XC52/54/58系列内部RAM后128字节。
寄存器间接寻址
(3)特殊功能寄存器。
直接寻址。
(4)外部数据存储器。
12MHz,则一
2-108XC5XCPU的机器周期与时钟周期是什么关系?
如果晶振频率为个机器周期是多少微秒?
1)、12个时钟周期构成1个机器周期。
2)、1uS
2-118XC5XX2CPU的机器周期与时钟周期是什么关系?
为什么说当为01H时,时钟频率为6MHz的8XC5XX2系统运行速度与时钟频率为系统的运行速度相同?
CKCON寄存器
12MHz的8XC5X
可以选择“机器周期/12时钟”或“机器周期/6时钟”。
当CKCON寄存器为0伯
时,时钟频率为6MHz的的8XC5XX2机器周期为:
一1uS。
而时钟频率为12MHz
6MHz
12
的8XC5X系统的机器周期为:
1uS。
12MHz
2-12在晶振输出端X2弓I脚应观察到什么样的波形?
当晶振频率较低时,如何使X2
引脚输出为理想状态下的波形?
方波。
2-13分析MCS-51写外部数据存储器写时序,说明为什么可使用74LS573或74LS373芯片扩展MCS-51的输入口,而不能扩展输出口。
请画出使用两片74LS373芯片扩展MCS-51的输入口、使用两片74LS237扩展输出口的电路图(假设系统中无需扩展外部存储器)。
使用边沿触发器作为输出锁存器时可以可靠的锁存输出数据。
2-148XC5XCPU复位后内部RAM各单元的内容是否改变?
程序计数器PC的值是什
么?
否。
此时PC=0000H.
2-15MCS-51单片机通过什么指令读/写外部数据存储器?
通过什么引脚选通外部数据存储器?
使用MOVX读写外部数据存储器。
通过RD或者WR.
2-16画出由一片80C32CPU、一片27128EPROM和一片6264SRAM组成的单片机应用系统,要求给出有关信号的连接以及各自存储空间的地址范围。
2-17在图2-7所示的电路中,假设驱动引脚为P1.0,则执行了如下程序段后,累加器
Acc的内容为什么?
这又说明了什么?
SETBP1.0
JBP1.0,NEXT1
MOVA,#0AAH
SJMPEXIT
NEXT1:
MOVA,#55H
EXIT:
NOP
Acc的内容为AAH。
因为JBP1.0,NEXT1是根据P1.0的电平进行判断转移,如果P1.0引脚的电平为高则转移。
因为三极管导通时P1.0引脚被钳位到低电平。
习题三参考答案
3-1MCS-51内部RAM低128字节支持哪些寻址方式?
请写出用不同寻址方式将内部RAM30H单元信息传送到累加器A的指令或程序片段;
内部RAM高128字节支持哪些寻址方式?
请写出将内部RAM80H单元内容传送到累加器A的指令或程序片段。
略:
3-2简述“RET与“RETI指令的区别。
1)RET是子程序返回指令,RETI是中断服务程序返回指令;
2)RETI在返回时会清除有关中断标志位,而RET不具有此功能。
3-3指出下列指令中每一操作数的寻址方式。
(1)MOV40H,A
(2)MOVA,@R0
(3)MOVX@DPTR,A
(4)MOVCA,@A+DPTR
(5)ADDA,#23H
(6)PUSHAcc
(7)MOVP1,32H
(8)MOVC,P1.0
(9)INCP0
(10)DECR2
(11)SJMPEXIT
3-4执行“CJNEA,#60,NEXT”指令后,寄存器A中的内容是否被改变?
请验证。
3-5写出实现下列要求的指令或程序片段,并在仿真机上验证。
⑴将内部RAM20H单兀内容与累加器A相加,结果存放在20H单兀中。
ADD
MOV
A,20H
20H,A
(2)将内部
RAM80H
单元内容与内部RAM31H单元内容相加,结果存放到内部RAM
的31H单元中。
R0,#80H
A,@R0
A,31H
31H,A
(3)将内部
RAM20H
单元内容传送到外部RAM20H单元中。
MOVA,20H
MOVDPTR,#0020H
MOVX@DPTR,A
(4)将程序状态字寄存器
PSW内容传送到外部RAM的0D0H单元中。
A,PSW
DPTR,#00D0H
MOVX
@DPTR,A
(5)
将内部RAM
08H〜7FH单元,共120字节传送到以8000H为首地址的外部
中。
DPTR,#8000H
R0,#08H
R2,#120
LOOP:
MOV
INC
R0
DPTR
DJNZ
R2,LOOP
END
RAM
(6)将外部RAM8000H〜0803FH单元,共64字节传送到以40H为首地址的内部RAM中。
MOVDPTR,#8000H
MOVR0,#40H
MOVR2,#64
MOVXA,@DPTR
MOV@R0,A
INCDPTR
INCR0
DJNZR2,LOOP
(7)将外部RAM8000H〜
0807FH单元,
共128字节传送到以
RAM中。
AURX1
EQU
0A2H
;
注意要自己定义
DPTR,
#8000H
INCAUXR1
#0000H
0000H为首地址的外部
MOVR0,#128LOOP:
MOVXA,@DPTR
DJNZR0,LOOP
(8)将存放在内部RAM的40H、41H和外部RAM的8000H、8001H的16位二进制数相加,结果存放在内部RAM的40H和41H单元中(假设低位字节存放在低地址中)。
MOVXA,@DPTR;
注意使用MOVX指令,下同
ADDA,40H
MOV40H,A
ADDCA,41H
MOV41H,A
(9)如果0〜9七段数码显示器对应的字模码3FH,06H,5BH,4FH,66H,6DH,7DH,
07H,7FH,6FH存放在1000H为首地址的程序存储器中,写出将数字4对应的字模码输出到外部RAM3003H单元(即扩展I/O端口地址)的程序段。
DPTR,#1000H
A,#4
MOVC
A,@A+DPTR
注意使用MOVC指令
DPTR,#3003H
;
注意使用MOVX指令
ORG
1000H
DB03FH,06H,5BH,4FH,55H,66H,6DH,6DH,07H,7FH,6FH
(10)将内部RAM01H〜0FFH单元内容清零。
MOVR0,#01H
MOV@R0,#0
CJNER0,#0FFH,LOOP
(11)我国FSK来电显示采用单数据消息格式,其中第0字节为消息类型(固定为04,即单数据消息格式标志),随后的一个字节为消息体长度,消息体内的消息字包括了来电日期(月、日)与时间(时、分)(8个字节)及主叫号码,最后一个字节为校验信息(校验算法可概括为:
从消息类型字节到主叫号码最后一个字节按256模式累加和,再求补码)。
试写出相应的校验程序片段(假设来电信息从内部RAM30H单元开始存放)。
(12)使内部RAM20H单元的b7、b3位清零,b6、b2位置1,b4、b0位取反,其他位不变。
SETB20H.6;
如果给定的地址不在20H~2FH之间,则不能用位寻址
SETB
20H.2
CLR
20H.7
20H.3
CPL
20H.4
20H.0
单元乘4(假设30H单元内容不超过
30H,#4
MOVA,30H
RLA
MOV30H,A
(15)将存放在内部RAM40H、41H和外部RAM8000H、8001H的四位BCD码相加,结果存放在内部RAM40H、41H、42H单元中(假设低位字节存放在低地址中,高位字节存放在高地址中)。
A,@DPTR
C
A,40H
DAA
40H,
A
ADDC
A,41H
41H,
42H,
(16)
将立即数
32H传送到内部
RAM30H
单元中。
30H,
#32H
(17)
RAM88H
R0,#88H
AUXR1
#DATATAB
#4000H
R7,#16
16个字节
A,#0
最开始的位置
R6,A
暂存A的值
A,@A+DPTR;
注意用M
@DPTR,
A;
注意使用
A,R6
同时职能用A做变址寄存器
C,ACC.3
ACC.0,C
(19)
用MCS-51位指令,实现P1.3
P1.2P1.1P1.0
C,P1.3
ANL
C,/P1.2
20H.0,C
暂存
C,P1.1
ORL
C,P1.0
C,20H.0
3-6
假设4位BCD码压缩存放在
R3、R2中,试编写
机上验证。
相当于
WXYZ+10000-仁WXYZ+9999
C;
A,R2
A,#99
DA
R2,A
A,R3
R3,A
3-7
禾U用双DPTR
功能,将存放在程序存储区内的数表
(18)将Acc.3位送Acc.O位。
(共计16字节,首地址为
DATATAB)传送到以4000H为首地址的外部RAM中。
的逻辑运算。
BCD减1的程序段,并在仿真
A的值增1,指向下一个字节
R7,LOOP
DATATAB:
DB01H,02H,03H,04H,01H,02H,03H,04H
3-8将存放在R3、R2中的三位压缩BCD码转换为二进制形式。
三位BCD码<
999
MAIN:
MOVA,R2
ANLA,#0F0H
SWAPA
MOVB,#10
MULAB
MOVB,A//存放十位
ANLA,#0FH
ADDA,B//加个位
MOVR2,A//暂存
//
MOVA,R3
MOVB,#100
MULAB//
ADDA,R2//
MOVR2,A
MOVA,B//
ADDCA,#0
MOVR3,A
3-9将存放在R2中不超过十进制99的二进制数转换为压缩BCD码,结果存放在R2中。
MOVA,R2
DIVAB
ORLA,BMOVR2,A
3-10在32位除16位的多位除法运算中,如果已知除数在8000H〜FFFFH之间,为缩
短运算时间,是否需要扩展被除数?
请写出相应的程序段。
不需要,因为32位二进制(FFFFFFFFH)表示的最大十进制数为4294967295,除
以80000H~FFFFH之间的数,其结果<
=1FFFFH(注:
“1”存放在进位位),所以用32位已经
足够存放商和余数。
程序如下:
0000H
LJMP
MAIN
0030H
42H,#0FFH
43H,#0FFH
44H,#0FFH
46H,#80H
47H,#00H
//MOV
40H,#0
41H,#0
LOOP1:
整体左移
1位
CLRC
R1,#4
R0,#45H
LOOP2:
移动4个字节
从最低位开始移
MOV45H,#0FFH
进位标志cy为0及F0为1均属于没有借位的情况
没有借位,商置1,用差替换
JCNEXT
MOV42H,R2
ORL45H,#01H
NEXT:
;
有借位,在保留被减数,商的最后一位清零(移位时已将0移入商的最后一位)
DJNZR7,LOOP1
//////////////////////////////////////////////////////////
3-11假设程序头中含有如下变量定义伪指令TXDBUFDATA#40H(注意:
原题错误,应该去掉“#”号,下同)
BDATADATA#28H
(1)请指出“MOVR0,#TXDBUF”指令和“MOVR0,TXDBUF”指令源操作数的寻址方式。
“MOVR0,#TXDBU”F指令(立即寻址);
“MOVR0,TXDBU”F指令(直接寻址)
(2)执行如下程序段后,内部RAM40H〜4FH单元的内容是什么?
28H单元的内容又
是什么?
MOVBDATA,#10HMOVR0,#TXDBUF
CLRA
LOOP:
MOV@R0,AINCAINCR0
DJNZBDATA,LOOPEND
内部RAM40H〜4FH单元的内容是:
0~F,28H单元的内容是0
3-12指出复位后工作寄存器组R7〜R0的物理地址。
如果希望快速保护工作寄存器组,请写出将2区作为当前工作寄存器区的程序段。
(1)07H~00H.
(2)SETBRS1CLRRS0
3-13简述顺序程序结构与分时操作程序结构的异同,以及这两种程序设计的注意事项。
习题四参考答案
4-1增强型MCS-51有几个中断优先级?
试通过修改IP、IPH寄存器内容,使串行口的
中断优先级最高,定时器T1的中断优先级最低。
(1)4;
(2)MOVIPH,#00010000B,MOVIP,#0