单片机与微机原理及应用课后答案张迎新等电子工业出版社.doc

上传人:坚持 文档编号:2100806 上传时间:2019-04-25 格式:DOC 页数:18 大小:37KB
下载 相关 举报
单片机与微机原理及应用课后答案张迎新等电子工业出版社.doc_第1页
第1页 / 共18页
单片机与微机原理及应用课后答案张迎新等电子工业出版社.doc_第2页
第2页 / 共18页
单片机与微机原理及应用课后答案张迎新等电子工业出版社.doc_第3页
第3页 / 共18页
单片机与微机原理及应用课后答案张迎新等电子工业出版社.doc_第4页
第4页 / 共18页
单片机与微机原理及应用课后答案张迎新等电子工业出版社.doc_第5页
第5页 / 共18页
点击查看更多>>
资源描述

1、第 2 章 单片机结构及原理 1、MCS-51 单片机内部包含哪些主要功能部件?它们的作用是什么? 答:(1)一个 8bit CPU 是微处理器的核心,是运算和逻辑计算的中心。 (2)片内震荡器及时钟电路:提供标准时钟信号,所有动作都依据此进行。(3)4K ROM 程序存贮器:存贮程序及常用表格。 (4)128B RAM 数据存贮器:存贮一些中间变量和常数等。 (5)两个 16bit 定时器/计数器:完全硬件定时器 (6)32 根可编程 I/O 口线:标准 8 位双向(4 个)I/O 接口,每一条 I/O 线都能独立地作输入或输出。 (7)一个可编程全双工串行口。 (8)五个中断源。 2、什么

2、是指令?什么是程序? 答:指令是规定计算机执行某种操作的命令。 程序是根据任务要求有序编排指令的集合。 3、如何认识 89S51/52 存储器空间在物理结构上可以划分为 4 个空间,而在逻辑上又可以划 分为 3 个空间? 答: 89S51/52 存储器空间在物理结构上设有个存储器空间:片内程序存储器、片外程序存储器、片内数 据存储器、片外数据存储器。在逻辑上有个存储器地址空间:片内、片外统一的 64KB 程序存储器地址 空间,片内 256数据存储器地址空间,片外 64的数据存储器地址空间。 4、开机复位后,CPU 使用的是哪组工作寄存器?他们的地址是多少?CPU 如何确定和改变 当前工作寄存器

3、组? 答:开机复位后,CPU 使用的是第 0 组工作寄存器,地址为 00H07H ,CPU 通过改变状态字寄存器 PSW 中的 RS0 和 RS1 来确定工作寄存器组。5、什么是堆栈?堆栈有何作用?在程序设计时,有时为什么要对堆栈指针 SP 重新赋值?如 果 CPU 在操作中要使用两组工作寄存器,SP 应该多大? 答:堆栈是一个特殊的存储区,主要功能是暂时存放数据和地址,通常用来保护断点和现场。堆栈指针 SP 复位后指向 07H 单元,00H1FH 为工作寄存器区,20H2FH 为位寻址区,这些单元有其他功能,因此 在程序设计时,需要对 SP 重新赋值。如果 CPU 在操作中要使用两组工作寄存

4、器,SP 应该至少设置为 0FH。 6、89S51/52 的时钟周期、机器周期、指令周期是如何分配的?当振荡频率为 8MHz 时,一 个单片机周期为多少微秒? 答:时钟周期为时钟脉冲频率的倒数,他是单片机中最基本的、最小的时间单位。机器周期是指完成一个 基本操作所需要的时间,一个机器周期由 12 个时钟周期组成。指令周期是执行一条指令所需要的时间, 由若干个机器周期组成。若 fosc=8MHz,则一个机器周期=1/812 s=1.5 s 7、89S51/52 扩展系统中,片外程序存储器和片外数据存储器共处同一地址空间为什么不会 发生总线冲突?答:访问片外程序存储器和访问数据存储器使用不同的指令

5、用来区分同一地址空间。 8、程序状态字寄存器 PSW 的作用是什么?常用状态标志有哪些位?作用是什么? 答:程序状态字PSW 是 8 位寄存器,用于存放程序运行的状态信息, PSW 中各位状态通常是在指令执行 的过程中自动形成的,但也可以由用户根据需要采用传送指令加以改变。各个标志位的意义如下:PSW.7( Cy):进位标志位。 PSW.6(AC ):辅助进位标志位,又称为半进位标志位。 PSW.5(F0):用户标志位。 PSW.4、PSW.3(RS1 和 RS0):寄存器组选择位。 PSW.2(OV ):溢出标志位。 PSW.1(空缺位):此位未定义。 PSW.0(P ):奇偶校验位。 9、

6、位地址 7CH 和字节地址 7CH 有何区别?位地址 7CH 具体在内存中什么位置? 答:字节地址 7CH 是片内数据存储器中的一个地址单元,该地址单元中可以存放 8 位二进制数,位地址 7CH 是内部数据存储器中位寻址区中的一位,该地址单元中可以存放 1 位二进制数。位地址 7CH 具体在 片内数据存储器字节地址为 2FH 中的第4 位(2FH.4) 。 10、89S51/52 中 4 个 I/O 端口的作用是什么?89S51/52 的片外三总线是如何分配的? 答:I/O 端口是单片机与外界联系的重要通道,实现与外部设备的信息的传输。总线分配:片外数据总(8 根)通过 P0 口输出,片外地址

7、总线(16 根)通过 P0 口(低 8 位)和 P2 口(高 8 位)输出,片外控制总 线(PSEN ,ALE , RD ,WR ,EA)主要通过 P3 口。 11、89S51/52 中 4 个 I/O 端口在结构上有何异同?89S51/52 单片机的个 I/O 口在结构上是基本相同的,但又各具特点。这四个端口都是位双向口,每个 端口都包括一个锁存器、一个输出驱动器和输入缓冲器。在无片外扩展存储器的系统中,这四个端口的每 一位都可以作为双向通用 I/O 端口使用。在作为一般的通用 I/O 输入时,都必须先向锁存器写入“”,使 输出驱动场效应管 FET 截止,以免误读数据。各自特点如下: (1)

8、P0 口为双向 8 位三态 I/O 口,它既可作为通用 I/O 口,又可作为外部扩展时的数据总线及低 8 位地 址总线的分时复用口。作为通用 I/O 口时,输出数据可以得到锁存,不需外接专用锁存器;输入数据可以 得到缓冲,增加了数据输入的可靠性。每个引脚可驱动 8 个 TTL 负载。 (2)P1 口为 8 位准双向 I/O 口,内部具有上拉电阻,一般作通用 I/O 口使用,它的每一位都可以分别定 义为输入线或输出线,作为输入时,锁存器必须置 1。每个引脚可驱动 4 个 TTL 负载。 (3)P2 口为 8 位准双向 I/O 口,内部具有上拉电阻,可直接连接外部 I/O 设备。它与地址总线高 8

9、 位复 用,可驱动 4 个 TTL 负载。一般作为外部扩展时的高 8 位地址总线使用。 (4)P3 口为 8 位准双向 I/O 口,内部具有上拉电阻,它是双功能复用口,每个引脚可驱动 4 个 TTL 负载。 作为通用 I/O 口时,功能与 P1 口相同,常用第二功能。 12、复位的作用是什么?有几种复位方法?复位后单片机的状态如何? 答:复位是单片机的初始化操作。单片机在 RST 引脚产生两个机器周期(即 24 个时钟周期)以上的高电 平即可实现复位。主要的复位方法有上电自动复位和按键手动复位两种。按键手动复位又分:按键电平复 位和按键脉冲复位。第 3 章 第三章 指令系统 1、简述下列名词术

10、语的基本概念:指令、指令系统、程序、汇编语言指令 答:指令:规定单片机进行某种操作的命令称为指令。 指令系统:单片机能够执行的各种指令的集合。 程序:一系列指令的有序集合称为程序。 汇编语言指令:用助记符形式来表示机器指令。2、 2、80C51 单片机有哪几种寻址方式?这几种寻址方式是如何寻址的? 答:共 7 种寻址方式,分别为:寄存器寻址,直接寻址,寄存器间接寻址,立即寻址,变址寻址,位寻址 和相对寻址。 寄存器寻址方式:由指令指出某一寄存器的内容做为操作数。 直接寻址方式:指令中操作数直接以单元地址的形式给出。 寄存器间接寻址方式 :寄存器中存放的是操作数,而寄存器间接寻址方式,寄存器中存

11、放的则是操作数 的地址,即操作数是通过寄存器间接得到的。 立即寻址方式:操作数在指令中直接给出。 变址寻址方式:变址寻址是为了访问程序存储器中的数据和表格。MCS 51 的变址寻址是以 DPTR 或PC 作基址寄存器,以累加器 A 作变址寄存器,并以两者内容相加形成的 16 位地址做为操作数地址,以达到 访问数据和表格的目的。 位寻址方式:指对片内 RAM 的位寻址区和某些可寻址的特殊功能寄存器进行位操作的寻址方式。 相对寻址方式:相对寻址方式是为解决程序转移而专门设置的,为转移指令所采用。 3、要访问特殊功能寄存器和片外数据寄存器,应采用哪些寻址方式? 答:访问特殊功能寄存器可以采用直接寻址

12、、立即寻址、寄存器寻址和位寻址(针对可以进行位寻址的特 殊功能寄存器)方式。访问片外数据存储器可采用寄存器间接寻址方式。 4、80C51 单片机的指令系统可以分为哪几类?说明各指令的功能。 答:51 单片机指令系统按功能可分为 5 类: (1)数据传送指令 主要进行数据的传送、交换等; (2)算术运算指令 主要进行基本的加减乘除运算; (3)逻辑运算指令 主要实现逻辑运算与移位运算; (4)控制转移指令 主要是实现对程序流程的控制; (5)位操作指令 5、外部数据传送指令有哪几条?有和区别? 答:外部数据传送指令有读指令和写指令两类,每类指令的寻址范围不同,分别为: 读外部存储器指令: MOV

13、X A,Ri ;寻址范围为256 字节 MOVX A,DPTR ;寻址范围为 64K 字节 写外部存储器指令: MOVX Ri,A ;寻址范围为 256 字节 MOVX DPTR,A ;寻址范围为 64K 字节 6、在 89S51 片内 RAM 中,已知(30H)=38H, (38H)=40H, (40H)=48H, (48H)=90H, 请分别分析下段程序按序执行后的结果。 MOV A,40H ;A=48H MOV R0,A ;R0=48H MOV P1,#0FFH ;P1=FFH MOV R0,30H ;(48H)=38H MOV DPTR,#1246H ;DPTR=1246H MOV 4

14、0H,38H ;(40H)=40H MOV R0,30H ;R0=38H MOV 90H,R0 ;(90H)=38H MOV 48H,#30H ;(48H)=30H MOV A,R0 ;A=40H MOV P2,P1 ;P2=38H 7、略 8、DA A 指令的作用是什么?怎样使用? 答:对十进制 BCD 数作加法时进行调整,当结果的低 4 位 A0A39 ,或半进位AC=1,则 A0A3 6, 否则不加;当结果的高 4 位A4A79,或进位 CY=1,则 A4A76,否则不加;这条指令是在进行 BCD 码加法运算时,跟在“ADD”和“ADDC”指令之后,用来对 BCD 码的加法运算结果自动进

15、行修正,使 其仍为BCD 码表示形式。9、试编程 将片外数据存储器 60H 中的内容传送到片内RAM54H 单元中。 答: MOV R0,#60H MOVX A,R0 MOV 54H,A 10、试编程将寄存器 R7 的内容传送到 R1 中去。 答: MOV A,R7 MOV R1,A 11、已知当前 PC 值为 210H,请用两种方法将程序存储器2F0H 中的常数送入累加器 A 中。 答:(1)以程序计数器PC 作为基址寄存器 MOV A,#0E0H MOVC A,A+PC (2)以数据指针 DPTR 作为基址寄存器 MOV DPTR,#02F0H MOV A ,#00H MOVC A,A+D

16、PTR 12、试说明下段程序中每条指令的作用,并分析当指令执行完后,R0 中的内容是什么? MOV R0,#0A7H ;R0=A7H,立即数送寄存器 R0 XCH A,R0 ;A=A7H,累加器 A 中的数据与 R0 中的数据进行交换 SWAP A ;A=7AH,累加器 A 中的高低四位进行交换 XCH A,R0 ;R0=7AH,数据交换回 R0 13、请用两种方法实现累加器 A 与寄存器 B 的内容交换。 答:(1)MOV R0,A MOV A,B MOV B,R0 (2)MOV R0,B XCH A,R0 14、试编程将片外 RAM 中 40H 单元的内容与 R1 的内容交换。答: MOV

17、 R0,#40H MOVX A,R0 XCH A,R1 MOVX R0,A 15、已知:A=0C9H,B=8DH,CY=1 。 执行指令 ADDC A,B 结果如何? A=57H,CY=1,OV=1 ,AC=1,P=1 执行指令 SUBB A,B 结果如何? A=3BH,CY=0 ,AC=1,OV=1 16、试编程将片外 RAM 中 30H 和 31H 单元中的内容相乘,结果存放在 32H(低位)和 33H(高位)单元中。 答: MOV R0,#30H MOVX A,R0 MOV B,A INC R0 MOVX A,R0 MUL AB INC R0 MOVX R0,A MOV A,B INC

18、R0 MOVX R0,A 17、17、试用 3 种方法将累加器 A 中的无符号数乘 2. 答:(1)MOV R0,A ADD A,R0 (2)MOV B,#2 MUL AB (3)RL A 18、18、分析依次执行下列指令的结果: MOV 30H,#0A4H ;(30H)=A4H MOV A,#0D6H ;A=D6H MOV R0,#30H ;R0=30H MOV R2,#47H ;R2=47H ANL A,R2 ;A=46H ORL A,R0 ;A=E6H SWAP A ;A=6EH CPL A ;A=91H XRL A,#0FFH ;A=6EH ORL 30H,A ;(30H)=EEH 1

19、9、19、求下列指令执行后,累加器 A 及 PSW 中进位 CY、奇偶位 P 和溢出位 OV 的值。 (1)当 A=5BH 时 ;ADD A,#8CH (2)当 A=5BH 时 ;ANL A,#7AH (3)当A=5BH 时 ;XRL A,#7FH (4)当 A=5BH,CY=1 时 ;SUBB A,#0E8H 答:(1)A=E7H,CY=1,P=0 ,OV=0 (2)A=5AH ,P=0 (3)A=24H ,P=0 (4)A=72H,CY=1,P=0,OV=0 20、把累加器 A 中的低 4 位数据送到外部数据存储器的 2000H 单元。 答: ANL A,#OFH MOV DPTR,#20

20、00H MOVX DPTR,A 21、试说明指令CJNE R1,#7AH ,10H 的作用,若本指令地址为 250H,其转移地址是多 少? 答:指令作用:如果以 R1 内容为地址的单元中的数据等于 7AH,则程序顺序执行,否则转移后继续执行。 若本指令地址为 250H,则转移地址为 250H03H10H= 263H。 22、将累加器 A 中的数据由 0 递增,加到 50,结果在累加器 A 中。 答: CLR A MOV R0,#50 L1: INC A DJNZ R0,L1 23、试说明压栈指令和弹栈指令的作用及执行过程。 答:压栈(入栈或进栈)指令的作用是将数据存入堆栈中,其执行过程是先将堆

21、栈指针 SP 的内容加 1,然 后将直接地址单元中的数据压入 SP 指向的单元中。若数据已推入堆栈,则SP 指向最后推入数据所在的存 储单元(即指向栈顶) 。 弹栈(出栈)指令的作用是将数据从堆栈中取出,其执行过程为先将堆栈指针 SP 所指出单元的内容送入 直接寻址单元中,然后将 SP 的内容减 1,此时 SP 指向新的栈顶。 24、下述程序执行后,SP=?,A=?,B= ?。 ORG 201H MOV SP,#40H MOV A,#30H LCALL 250H ;下条指令地址 208H 送41H、42H,SP=42H ADD A,#10H MOV B,A ;地址为 20AH L1: SJMP

22、 L1 ORG 250H MOV DPTR,#20AH PUSH DPL ;SP+1=43H,DPL(43H) PUSH DPH ;SP+1=44H,DPH(44H) RET ;20AHPC 答:上述程序执行后,SP=42H,A=30H,B=30H。 25、发光二极管点亮规律:先是第 1 和第 8 个亮,延时一段时间后,第 2 和第 7 个亮,延时 后,再是第 3 和第 6 个亮,延时后,最后是第 4 和第 5 个点亮,延时后循环。 26、若系统晶振频率为 6MHz,求子程序 DELAY 的延时时间,若想加长或缩短时间,应该 怎样修改? 答: DELAY: MOV R2,#0FAH L1: MOV R3,#0FAH L2: DJNZ R3,L2 DJNZ R2,L1 RET 总时间计算:T=4 s( 2504 s4 s)250 4 s=251.008ms 估算:T=2504 s250=250ms 若想加长延时时间,可以增加循环次数或再加一重循环; 若想减小延时时间,可以减少循环次数或较少一重循环。 27、P1 口连接 8 个共阳极连接的发光二极管,是编制灯亮移位程序。 答: MOV A,#0FEH L1: MOV P1,A RL A

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育教学资料库 > 试题真题

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。