2022年单片机原理及应用第二版课后习题答案

上传人:人*** 文档编号:567299341 上传时间:2024-07-19 格式:PDF 页数:19 大小:101.64KB
返回 下载 相关 举报
2022年单片机原理及应用第二版课后习题答案_第1页
第1页 / 共19页
2022年单片机原理及应用第二版课后习题答案_第2页
第2页 / 共19页
2022年单片机原理及应用第二版课后习题答案_第3页
第3页 / 共19页
2022年单片机原理及应用第二版课后习题答案_第4页
第4页 / 共19页
2022年单片机原理及应用第二版课后习题答案_第5页
第5页 / 共19页
点击查看更多>>
资源描述

《2022年单片机原理及应用第二版课后习题答案》由会员分享,可在线阅读,更多相关《2022年单片机原理及应用第二版课后习题答案(19页珍藏版)》请在金锄头文库上搜索。

1、学而不思则惘,思而不学则殆第 1章单片机概述参考答案1.1 答:微控制器,嵌入式控制器1.2 答: CPU、存储器、 I/O 口、总线1.3 答: C 1.4 答: B 1.5 答:微处理器、微处理机和CPU 它们都是中央处理器的不同称谓,微处理器芯片本身不是计算机。而微计算机、单片机它们都是一个完整的计算机系统,单片机是集成在一个芯片上的用于测控目的的单片微计算机。嵌入式处理器一般意义上讲,是指嵌入系统的单片机、DSP、嵌入式微处理器。目前多把嵌入式处理器多指嵌入式微处理器,例如ARM7 、ARM9 等。嵌入式微处理器相当于通用计算机中的 CPU。与单片机相比,单片机本身(或稍加扩展)就是一

2、个小的计算机系统,可独立运行,具有完整的功能。而嵌入式微处理器仅仅相当于单片机中的中央处理器。为了满足嵌入式应用的特殊要求,嵌入式微处理器虽然在功能上和标准微处理器基本是一样的,但在工作温度、抗电磁干扰、可靠性等方面一般都做了各种增强。1.6 答: MCS-51 系列单片机的基本型芯片分别:8031、8051 和 8071。它们的差别是在片内程序存储器上。 8031 无片内程序存储器、8051 片内有 4K 字节的程序存储器ROM ,而 8751 片内有集成有4K 字节的程序存储器EPROM。1.7 答:因为 MCS-51 系列单片机中的“ MCS ” 是 Intel 公司生产的单片机的系列符

3、号,而 51 系列单片机是指世界各个厂家生产的所有与8051 的内核结构、指令系统兼容的单片机。1.8 答:相当于MCS-51 系列中的87C51,只不过是AT89S51 芯片内的4K 字节 Flash 存储器取代了 87C51 片内的 4K 字节的 EPROM。1.9 单片机体积小、价格低且易于掌握和普及,很容易嵌入到各种通用目的的系统中,实现各种方式的检测和控制。单片机在嵌入式处理器市场占有率最高,最大特点是价格低,体积小。DSP 是一种非常擅长于高速实现各种数字信号处理运算(如数字滤波、FFT、频谱分析等)的嵌入式处理器。由于对其硬件结构和指令进行了特殊设计,使其能够高速完成各种复杂的数

4、字信号处理算法。广泛地用于通讯、网络通信、数字图像处理,电机控制系统,生物信息识别终端,实时语音压解系统等。这类智能化算法一般都是运算量较大,特别是向量运算、指针线性寻址等较多,而这些正是DSP 的长处所在。与单片机相比,DSP 具有的实现高速运算的硬件结构及指令和多总线,DSP 处理的算法的复杂度和大的数据处理流量以及片内集成的多种功能部件更是单片机不可企及的。嵌入式微处理器的基础是通用计算机中的CPU,它的地址总线数目较多能扩展较大的存储器空间,所以可配置实时多任务操作系统(RTOS)。RTOS 是嵌入式应用软件的基础和开发平台。正由于嵌入式微处理器能运行实时多任务操作系统,所以能够处理复

5、杂的系统管理任务和处理工作。因此,广泛地应用在移动计算平台、媒体手机、工业控制和商业领域(例如,智能工控设备、ATM 机等)、电子商务平台、信息家电(机顶盒、数字电视)以及军事上的应用。1.10 广义上讲,凡是系统中嵌入了“ 嵌入式处理器 ” ,如单片机、DSP、嵌入式微处理器,都称其为 “ 嵌入式系统 ” 。但多数人把“ 嵌入 ” 嵌入式微处理器的系统,称为“ 嵌入式系统 ” 。 目前 “ 嵌入式系统 ” 还没有一个严格和权威的定义。目前人们所说的“ 嵌入式系统 ” ,多指后者。第 2 章AT89S51 单片机的硬件结构1答: AT89S51 单片机的片内都集成了如下功能部件:(1)1 个微

6、处理器( CPU) ; (2)128 个数据存储器( RAM )单元; ( 3)4K Flash 程序存储器;(4)4 个 8 位可编程并行I/O 口( P0口、 P1 口、 P2 口、 P3 口) ; (5)1 个全双工串行口; (6)2 个 16 位定时器 /计数器;(7)1 个看精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 1 页,共 19 页学而不思则惘,思而不学则殆门狗定时器;(8)一个中断系统,5 个中断源, 2 个优先级;(9)25 个特殊功能寄存器(SFR) ,(10)1 个看门狗定时器。2答:当脚为高电平时,单片机读片内程序存储

7、器(4K 字节 Flash)中的内容,但在PC 值超过 0FFFH(即超出4K 字节地址范围)时,将自动转向读外部程序存储器内的程序;当脚为低电平时,单片机只对外部程序存储器的地址为0000HFFFFH 中的内容进行读操作,单片机不理会片内的4K 字节的 Flash 程序存储器。3答: 2s4答: 1 个机器周期等于12 个时钟振荡周期。5. 答: 64K 程序存储器空间中有5 个特殊单元分别对应于5 个中断源的中断服务程序入口地址,见下表:表5 个中断源的中断入口地址入口地址中断源0003H 外部中断0 ( )000BH 定时器 0 (T0) 0013H 外部中断1 ( )001BH 定时器

8、 1 (T1) 0023H 串行口6. 答: 28H;88H。7答: 50H;88H。8答: P标志位的值为0。9答:(A)错; (B)错; ( C)对;(D)对。10. 答: 04H;00H;0 组。11答: (A) 对; (B) 对; (C) 错; (D) 对。12. 答:字节地址00H-1FH 的单元可作为工作寄存器区。13答: (A) 错; (B) 错; (C) 错; (D) 错。14答:(C)。15. 答: PC;PC。16答: 64K 字节。17 P0 口每位可驱动8 个 LSTTL 输入,而P1、P2、P3 口的每一位的驱动能力,只有P0口的一半。当 P0 口的某位为高电平时,可

9、提供400mA 的电流;当P0口的某位为低电平(0.45V)时,可提供3.2mA 的灌电流,如低电平允许提高,灌电流可相应加大。所以,任何一个口要想获得较大的驱动能力,只能用低电平输出。18答:按下复位按钮。19. 答: (A) 对;(B) 对; ( C)错; (D)错。20. 答: (A) 对;(B) 对; ( C)对; (D)错。第 3 章AT89S51 的指令系统1答:(1)错( 2)错( 3)对( 4)错( 5)错( 6)错( 7)错( 8)对( 9)错( 10)对( 11)对( 12)错。2答:(A)对( B)对( C)错( D)错。3答: A,PC,DPTR。4答:只能使用直接寻址

10、方式。5答:操作码,操作数,操作码。6. 答: 1031H。7答:程序,数据。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 2 页,共 19 页学而不思则惘,思而不学则殆8答:地址。9答: A 的内容与B 的内容互换。10答:(A)=50H, (SP)=50H, (51H) =30H, (52H)=50H, (PC) 5030H 11答: (A)ANL A,#87H (B)ANL A,#0C3H (C)ORL A ,#0CH 12答:(A)=0CBH 。13答:(A)=00H, (R3)=0AAH 。14答:(DPH )=3CH , (DPL )

11、=5FH, (SP)=50H 15答:(SP)=62H, (61H)=30H, (62H)=70H。16答:MOV R7,A PUSH Acc MOV A,B MOVX DPTR,A 17答:(D) 。18答:(C) 。19答:基本型的51 子系列单片机, 由于其片内RAM 的地址范围为00H7FH,而 80HFFH为特殊功能寄存器区,而对特殊功能寄存器寻址,只能使用直接寻址方式。对片内RAM 寻址,当使用寄存器间接寻址是采用R0 或 R1 作为间接寻址的,因此R0 或 R1 的内容不能超过7FH。增强型的52 子系列单片机,片内RAM 的地址范围为00HFFH,因此作为间接寻址寄存器的R0

12、或 R1 的内容就不受限制。第 4 章AT89S51 汇编语言程序的设计与调试参考答案1答:伪指令是程序员发给汇编程序的命令,只有在汇编前的源程序中才有伪指令,即在汇编过程中的用来控制汇编过程的命令。所谓“ 伪 ” 是体现在汇编后,伪指令没有相应的机器代码产生。常用伪指令及其功能如下:ORG(ORiGin )汇编起始地址命令;END(END of assembly) 汇编终止命令;EQU( EQUate)标号赋值命令; DB(Define Byte )定义数据字节命令;DW (Define Word )定义数据字命令;DS(Define Storage)定义存储区命令;BIT 位定义命令2 答

13、:手工汇编:通过查指令的机器代码表(表3-2) ,逐个把助记符指令“ 翻译 ” 成机器代码,再进行调试和运行。这种人工查表“ 翻译 ” 指令的方法称为“ 手工汇编 ” 。机器汇编:借助于微型计算机上的软件(汇编程序 )来代替手工汇编。通过在微机上运行汇编程序,把汇编语言源程序翻译成机器代码。反汇编:将二进制的机器码程序翻译成汇编语言源程序的过程称为“ 反汇编 ” 。3答:从1000H 开始的各有关存储单元的内容(16 进制 )如下:4D 41 49 4E 12 34 30 00 00 70 78 7F E4 F6 D8 FD 75 81 07 02 4在编写子程序时应注意以下问题:(1)子程序

14、的第一条指令前必须有标号。(2)主程序调用子程序,有如下两条子程序调用指令: 绝对调用指令ACALL addr11 。被调用的子程序的首地址与绝对调用指令的下一条指令的高5 位地址相同,即只能在同一个2KB 区内。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 3 页,共 19 页学而不思则惘,思而不学则殆 长调用指令LCALL addr16 。addr16 为直接调用的目的地址,被调用的子程序可放置在64KB程序存储器区的任意位置。(3)子程序结构中必须用到堆栈,用来保护断点和现场保护。(4)子程序返回时,必须以RET 指令结束。(5)子程序可以

15、嵌套,但要注意堆栈的冲突。5答:参考程序如下:MOV A,45H ANL A ,#0FH ORL A,#0FH MOV 45H,A 6答: A=80H , SP=40H, (41H)=50H ,(42H)=80H ,PC=8050H 7答:参考程序如下: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: RET 8答:参考程序如下:START:MOV 41H,#0 MOV R0,#20H

16、 MOV R2,#20H LOOP:MOV A ,R0 JNZ NEXT INC 41H NEXT :INC R0 DJNZ R2,LOOP RET 9答:参考程序如下:ORG 0100H MOV R2, #20H 要比较的数据字节数MOV A , #21H MOV R1 , A DEC R2 MOV A , R1 LOOP: MOV R3,A DEC R1 CLR C SUBB A,R1 JNC LOOP1 MOV A,R1 SJMP LOOP2 LOOP1: MOV A,R3 LOOP2: DJNZ R2, LOOP MOV R0,A RET 精选学习资料 - - - - - - - -

17、- 名师归纳总结 - - - - - - -第 4 页,共 19 页学而不思则惘,思而不学则殆10答:(1)SP=SP+1=61H (61H)=PC 的低字节 =03H SP=SP+1=62H (62H)=PC 的高字节 =20H (2)PC=3456H (3)可以(4)2KB 2048 Byte 11答:可对程序做如下修改:ORG 0100H DEL: MOV R7, #200 DEL1: MOV R6, #123 ; 将原来的立即数125 改为 123 DEL2: DJNZ R6, DEL2 NOP ; 增加的指令DJNZ R7, DEL1 RET 程序修改后的延时时间为:1+(1+123

18、*2+1+2)*200+2=50003us=50.003ms 第 5 章AT89S51 的中断系统参考答案1答: 0013H;001BH 2答:串行口中断; 外部中断1 3 答: RETI 指令在返回的同时清除相应的优先级触发器,以允许下次中断,而RET 指令则没有这个操作。除了这一点两条指令不同外,其它操作都相同。4答: D 5 答:在一个单一中断的系统里,AT89S51 单片机对外部中断请求的响应时间总是在38个机器周期之间。在下述三种情况下,AT89S51 将推迟对外部中断请求的响应:(1)AT89S51 正在处理同级或更高优先级的中断。(2)所查询的机器周期不是当前正在执行指令的最后一

19、个机器周期。(3)正在执行的指令是RETI 或是访问IE 或 IP 的指令。如果存在上述三种情况之一,AT89S51 将丢弃中断查询结果,将推迟对外部中断请求的响应。6答: D 7答: PC、PC、程序存储器8答 : 参考程序段如下:SETB IT1 SETB EX1 SETB EA 9答:(A)10答:一个中断源的中断请求被响应,必须满足以下必要条件:(1)总中断允许开关接通,即IE 寄存器中的中断总允许位EA=1 。(2)该中断源发出中断请求,即该中断源对应的中断请求标志为“1”。(3)该中断源的中断允许位 =1,即该中断被允许。(4)无同级或更高级中断正在被服务。精选学习资料 - - -

20、 - - - - - - 名师归纳总结 - - - - - - -第 5 页,共 19 页学而不思则惘,思而不学则殆11答: (A) 、 ( C) 、 ( D)12答:参见电路如图5-10,参考程序如下:ORG 0000H LJMP MAIN ORG 0013H LJMP INT_EX1 ORG 0030H MAIN: CLR IT0 ;采用电平触发,低电平有效中断SETB EX1 ;允许外部中断1 SETB EA ;插入一段用户程序WAIT: MOV PCON,#01H ;单片机进入休眠方式等待中断NOP LJMP WAIT ;以下为外部中断1 服务子程序INT_EX1 :JB P1.2,N

21、EXT1 ;判断是不是3 号中断LJMP INT_IR3 ;跳转到3 号中断处理程序NEXT1: JB P1.1,NEXT2 ;判断是不是2号中断LJMP INT_IR2 ;跳转到2 号中断处理程序NEXT2: LJMP INT_IR1 ;跳转到1 号中断处理程序ORG 1000H INT_IR3: 相应中断处理程序RETI ;中断返回ORG 1100H INT_IR2: 相应中断处理程序RETI ;中断返回ORG 1200H INT_IR1: 相应中断处理程序RETI ;中断返回第 6 章AT89S51 的定时 /计数器参考答案1答:(A)对; (B)错; ( C)错;(D)错;2答:因为机

22、器周期:所以定时器 /计数器工作方式0 下,其最大定时时间为同样可以求得方式1 下的最大定时时间为262.144ms;方式 2 下的最大定时时间为1024ms。3答:定时 /计数器作定时时,其计数脉冲由系统振荡器产生的内部时钟信号12 分频后提供。定时时间与时钟频率和定时初值有关。4答:由于确认1 次负跳变要花2 个机器周期,即24 个振荡周期,因此外部输入的计数脉冲的最高频率为系统振荡器频率的1/24。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 6 页,共 19 页学而不思则惘,思而不学则殆5答:定时器 /计数器 T0 在计数和定时工作完成后

23、,均采用中断方式工作。除了第一次计数工作方式设置在主程序完成外,后面的定时或计数工作方式分别在中断程序完成,用一标志位识别下一轮定时器/计数器 T0 的工作方式。参考程序如下:ORG 0000H LJMP MAIN ORG 000BH LJMP IT0P MAIN: 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

24、: AJMP WAIT IT0P: CLR EA;CPU 关中断JB F0,COUNT ;F0=1,转计数方式设置MOV TMOD,#00H ;定时器 /计数器 T0 为定时方式0 MOV TH0,#0FEH ;定时 1ms 初值赋值MOV TL0,#0CH SETB EA RETI COUNT: MOV TMOD,#06H MOV TL0,#156 SETB EA RETI 6. 答:定时器 /计数器的工作方式2 具有自动恢复初值的特点,适用于精确定时,比如波特率的产生。7. 答:根据题意, 从 P1.0 输出的矩形脉冲的高低电平的时间为10:1,则高低电平的时间分别为363.63 s和 3

25、6.37 s。如果系统采用6MHz 晶振的话, T cy=2 s,因此高低电平输出取整,则约为364s和 36s。参考程序如下:ORG 0000H LJMP MAIN ORG 000BH LJMP IT0P MAIN: MOV TMOD,#02H ;定时器 /计数器 T0 为定时方式2 MOV TL0,#4AH ;定时 364s初值赋值SETB TR0 ;启动 T0,开始计数SETB ET0 ;允许 T0 中断SETB EA ;CPU 开中断SETB P1.0 WAIT :AJMP WAIT IT0P:CLR EA CLR P1.0 ;关中断MOV R0,#9 DLY:DJNZ R0,DLY

26、;延时 36sMOV TL0,#4AH ;定时 364s初值赋值精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 7 页,共 19 页学而不思则惘,思而不学则殆SETB P1.0 SETB EA RETI 8. 答:方法1,在第一个定时器的中断程序里关闭本定时器的中断程序,设置和打开另一个定时器;在另一个定时器的中断程序中关闭本定时中断,设置和打开另一个定时器。这种方式的定时时间为两个定时器定时时间的和。方法 2,一个作为定时器,在定时中断后产生一个外部计数脉冲(比如由P1.0 接 产生) ,另一个定时器工作在计数方式。这样两个定时器的定时时间为一个

27、定时器的定时时间乘以另一个定时器的计数值。9. 答:由 T1(P3.5) 口控制定时器T1 的启动和关闭。10. 答:采用方式1定时工作方式。最大脉冲宽度为131.072ms。11. 答:将 P1.1 的输入脉冲接入INT0 ,即使用 T0 计数器完成对P1.1 口的脉冲计数。参考程序如下:ORG 0000H LJMP MAIN ORG 000BH LJMP IT0P MAIN: JNB P1.0,MAIN MOV TMOD,#05H ;定时器 /计数器 T0 为计数方式1 SETB TR0 ;启动 T0,开始计数SETB ET0 ;允许 T0 中断SETB EA ;CPU 开中断WAIT:

28、JB P1.2,WAIT CLR EA CLR TR0 MOV R1,TH0 MOV R0,TL0 AJMP $ IT0P: INC R2 RETI 12. 答: THx 与 TLx (x=0,1) 是由特殊功能寄存器构成的计数器,其内容可以随时用指令更改,更改后的新值是立即刷新。但在读 THx 、TLx 的值时, 应该先读THx 值,后读 TLx ,再读 THx 。若两次读得THx 相同,则可确定读得的内容正确。若前后两次读得的THx 有变化,再重复上述过程。第 7 章AT89S51 的串行口参考答案1答:方式1。2答:相等的。3答: A对; B对; C错; D对; E对。4答: C 5答:

29、 C 6答:当接收方检测到RXD 端从 1 到 0 的跳变时就启动检测器,接收的值是3 次连续采样,取其中 2 次相同的值, 以确认是否是真正的起始位的开始,这样能较好地消除干扰引起的影响,以保证可靠无误的开始接受数据。7答:串行口有4 种工作方式:方式0、方式 1、方式 2、方式 3;有 3 种帧格式,方式2 和 3具有相同的帧格式;方式0 的发送和接收都以fosc/12 为固定波特率,方式 1 的波特率 =2SMOD/32 定时器 T1 的溢出率精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 8 页,共 19 页学而不思则惘,思而不学则殆方式

30、2 的波特率 =2SMOD/64 fosc 方式 3 的波特率 =2SMOD/32 定时器 T1 的溢出率8答:字符 “B”的 ASCII 码为 “42H”,帧格式如下:9答:因为定时器/计数器在方式2 下,初值可以自动重装,这样在做串口波特率发生器设置时,就避免了执行重装参数的指令所带来的时间误差。设定时器 T1 方式 2 的初值为X,计算初值X 可采用如下公式:波特率= 10答:经计算,计数初值为FAH,初始化程序如下:ANL TMOD,#0F0H ;屏蔽高4位ORL TMOD,#20H ;控制字MOV TH1,#0FAH ;写入计数初值MOV TL1,#0FAH MOV SCON,#40

31、H 11答:见7.3 节的介绍。12答:见7.5.3 小节的介绍13答:串口每秒钟传送的字符为:1800/60=30 个字符 /秒所以波特率为:30 个字符 /秒 10 位/个字符 =300b/s 14答:串行口的方式0 为同步移位寄存器输入输出方式,常用于外接移位寄存器,以扩展并行 I/O 口,一般不用于两个MCS-51 之间的串行通信。该方式以fosc/12 的固定波特率从低为位到高位发送或接受数据。15答:直接以TTL 电平串行传输数据的方式的缺点是传输距离短,抗干扰能力差。因此在串行传输距离较远时,常采用 RS-232C、RS-422A 和 RS-485 标准串行接口。 主要是对传输的

32、电信号不断改进, 如 RS-232C 传输距离只有几十米远,与直接以TTL 电平串行传输相比,采用了负逻辑,增大 “0”、“1”信号的电平差。而 RS-422A 和 RS-485 都采用了差分信号传输,抗干扰能力强,距离可达1000 多米。 RS-422A 为全双工, RS-485 为半双工。第 8 章AT89S51 单片机扩展存储器的设计参考答案1答:程序、数据。2答: 80H。3答:片选。4答: 16KB 。5答:程序、数据。6答: 2K,14。7答: 0FFFH。8答:(D)9答:本题主要考察对外部存储器的读、写操作,只要记住正确使用MOVX 指令就可以了。编程思路:首先读取2001H

33、的值,保存在寄存器A 中,将寄存器A 的高四位和低四位互换,再屏蔽掉低四位然后将寄存器A 的值保存到30H 中,然后再读取2002H 的值,保存在寄存器A中,屏蔽掉高四位,然后将寄存器A 的值与 30H 进行或运算,将运算后的结果保存在2002H中。ORG 0000H MAIN :MOV DPTR,#2001H ;设置数据指针的初值MOVX A,DPTR ;读取 2001H 的值精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 9 页,共 19 页学而不思则惘,思而不学则殆SWAP A ANL A,#0F0H ;屏蔽掉低四位MOV 30H, A ;保

34、存 A INC DPTR ;指针指向下一个MOVX A,DPTR ;读取 2002H 的值ANL A,#0FH ;屏蔽掉高四位ORL A,30H ;进行拼装MOVX DPTR,A ;保存到2002H END 10答:本题主要考察对外部数据块的写操作;编程时只要注意循环次数和MOVX 指令的使用就可以了。ORG 0000H MAIN :MOV A,#0 ;送预置数给A MOV R0,#0FFH ;设置循环次数MOV DPTR,#4000H ;设置数据指针的初值LOOP:MOVX DPTR, A ;当前单元清零IN C DPTR ;指向下一个单元DJNZ R0, LOOP ;是否结束END 11答

35、:因为控制信号线的不同:外扩的 RAM 芯片既能读出又能写入,所以通常都有读写控制引脚,记为 OE* 和 WE* 。 外扩 RAM的读、写控制引脚分别与AT89S51 的 RD* 和 WR* 引脚相连。外扩的 EPROM 在正常使用中只能读出,不能写入,故EPROM 芯片没有写入控制引脚,只有读出引脚,记为OE*,该引脚与AT89S51 单片机的PSEN* 相连。12答:图中采用了译码法。4 片地址分别为0000H-3FFFH 、4000H-7FFFH 、8000H-BFFFH 、C000H-FFFFH 。13答:(1)参见图8-20 或图 8-21,去掉一片2764。(2)指出该应用系统程序

36、存储器空间和数据存储器空间各自的地址范围。14答:(1)A 组跨接端子的内部正确连线图(2)B 组跨接端子的内部正确连线图注意:答案不唯一,还有其他连接方法,也可满足题目要求。第 9 章AT89S51 扩展 I/O 接口的设计参考答案1答:(A)错, 81C55 具有地址锁存功能;(B)错,在81C55 芯片中,引脚IO/M* 、A2、A1、A0 决定端口地址和RAM 单元编址;(C)错, 82C55 不具有三态缓冲器;(D)错, 82C55 的 B 口只可以设置成方式0 和方式 1。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 10 页,共 1

37、9 页学而不思则惘,思而不学则殆2答: I/O 端口简称I/O 口,常指 I/O 接口电路中具有端口地址的寄存器或缓冲器。I/O 接口是指单片机与外设间的I/O 接口芯片; I/O 接口功能: (1) 实现和不同外设的速度匹配;(2) 输出数据缓存; (3) 输入数据三态缓冲。3答: 3 种传送方式:(1) 同步传送方式:同步传送又称为有条件传送。当外设速度可与单片机速度相比拟时,常常采用同步传送方式。(2) 查询传送方式:查询传送方式又称为有条件传送,也称异步传送。单片机通过查询得知外设准备好后,再进行数据传送。异步传送的优点是通用性好,硬件连线和查询程序十分简单,但是效率不高。(3) 中断

38、传送方式:中断传送方式是利用 AT89S51 本身的中断功能和I/O 接口的中断功能来实现I./O 数据的传送。单片机只有在外设准备好后,发出数据传送请求,才中断主程序,而进入与外设进行数据传送的中断服务程序,进行数据的传送。中断服务完成后又返回主程序继续执行。因此,中断方式可大大提高工作效率。4答:两种。 (1) 独立编址方式:独立编址方式就是I/O 地址空间和存储器地址空间分开编址。独立编址的优点是I/O 地址空间和存储器地址空间相互独立,界限分明。但却需要设置一套专门的读写I/O 的指令和控制信号。(2) 统一编址方式:这种方式是把I/O 端口的寄存器与数据存储器单元同等对待,统一进行编

39、址。统一编址的优点是不需要专门的I/O 指令,直接使用访问数据存储器的指令进行I/O 操作。 AT89S51 单片机使用的是 I/O 和外部数据存储器RAM 统一编址的方式。5答:82C55 通过写入控制字寄存器的控制字的最高位来进行判断,最高位为1 时,为方式控制字,最高位为0 时,为 C 口按位置位 /复位控制字。6答:本题主要考察对82C55 的 C 口的操作。其方式控制字的最高位为0 时,低四位控装置对 C 口置复位。由题目可知方式控制寄存器的地址为7FFFH。ORG 0100H MAIN: MOV DPTR,#7FFFH ;控制字寄存器地址7FFFH 送 DPTR MOV A,#0E

40、H ;将 PC7 置 0 MOVX DPTR,A MOV A,#09H ;将 PC4 置 1 MOVX DPTR,A END 7答:当外设输入一个数据并送到PA7PA0 上时,输入设备自动在选通输入线A 向 82C55发送一个低电平选通信号,则把PA7-PA0 上输入的数据存入PA 口的输入数据缓冲/锁存器;然后使输入缓冲器输出线IBFA 变成高电平,以通知输入设备,82C55 的 PA 口已收到它送来的输入数据。 82C55 检测到联络线A 由低电平变成了高电平、IBFA 为 1 状态和中断允许触发器INTEA 为 1 时,使输出线INTRA (PC3)变成高电平,向AT89S51 发出中断

41、请求。 (INTEA 的状态可由用户通过对PC4 的置位 /复位来控制。 AT89S51 响应中断后, 可以通过中断服务程序从PA 口的输入数据缓冲/锁存器读取外设发来的输入数据。当输入数据被CPU 读走后, 82C55 撤销 INTRA 上的中断请求,并使IBFA 变为低电平,以通知输入外设可以送下一个输入数据。8答: 81C55 的端口有以下几种:命令/状态寄存器、 PA 口、 PB 口、 PC 口、计数器的高8 位寄存器与低8 位寄存器以及RAM 单元。引脚IO/ , A2、A1、A0 决定端口地址。TIMERIN是计数脉冲输入引脚,输入脉冲的上跳沿用于对81C55 片内的 14 位计数

42、器减1。 为计数器输出引脚。 当 14 位计数器减为0 时就可以在该引线上输出脉冲或方波,输出的信号的波形与所选的计数器工作方式有关。9答:电路图可以参考图9-10,PA 口每一位接二极管的正极,二极管的负极接地。PB 口每 1位接一开关和上拉电阻,开关另一端直接接地。这样只需要将读到的PB 口的值送给PA 口就可以满足题目要求了。ORG 0100H MIAN :MOV A,#10000010B ;设置 PA 口方式 0 输出, PB 口方式 0 输入MOV DPTR,#0FF7FH ;控制口地址送DPTR MOVX DPTR,A ;送方式控制字精选学习资料 - - - - - - - - -

43、 名师归纳总结 - - - - - - -第 11 页,共 19 页学而不思则惘,思而不学则殆MOV DPTR,#0FF7DH ;PB 口地址送DPTR MOVX A, DPTR ;读入开关信息MOV DPTR,#0FF7CH ;PA 口地址送DPTR MOVX DPTR,A ;PA 口的内容送PB 口点亮相应的二极管END 10答: 81C55 计数器的初值范围是:3FFFH-2H 。当频率为4MHz,初值为 3FFFH 时,最大定时时间为: 0.004096S 11答:将1MHz 的脉冲改变为10ms 的方波,实际上就是分频。分频前后频率之比为100:1,这样只要将定时器初值设置为64H

44、就可以了。(假设 I/O 口地址为7F00H-7F05H )START:MOV DP TR,#7F04H ;指针指向计数器低8 位MOV A,#64H ;送初值给A MOVX DPTR ,A ;初值送给计数器低8 位INC DPTR ;指向计数器高8 位MOV A,#40H ;计数器方波输出MOVX DPTE,A MOV DPTR,#7F00H ;指向命令 /状态口MOV A,#0C2H ;设定控制字MOVX DPTE,A ;启动计数器END 第 10 章AT89S51 与键盘、显示器、拨盘、打印机的接口设计参考答案1. 答: A MAX7219 是专用显示器芯片,不用于键盘;B错: CH45

45、1 芯片也可用于控制键盘;C对: BUSY 信号可作为查询信号或中断请求信号使用,但此时信号不用;E错:LED数码管的字型码是可以变的,例如表 10-1 中的 “a”段对应段码字节的最高位。“dp”段对应段码字节的最低位,字型码就改变了。2. 答:在按键的闭合和断开过程中,由于开关的机械特性,导致了按键抖动的产生。如果不消除按键的机械抖动,按键的状态读取将有可能出现错误。消除按键抖动一般是采用软件或硬件去抖。软件去抖的原理:在第一次检测到有键按下时,该键所对应的行线是为低电平,执行一端延时 10ms 的子程序后,确认该行线电平是否仍然为低电平,如果仍为低电平,则确认为该行确实有键按下。3. 答

46、:静态显示时,数据是分开送到每一位LED 上的。而动态显示则是数据是同时送到每一个 LED 上,再根据位选线来确定是哪一位LED 被显示。静态显示亮度很高,但口线占用较多。动态显示口线占用较少,适合用在显示位数较多的场合。4. 答: 80H(共阴极);7FH(共阳极)。5. 答:按键设置在行、列线交点上,行、列线分别连接到按键开关的两端。行线通过上拉电阻接到 +5V 上,无按键按下时,行线处于高电平状态,而当有按键按下时,行线电平状态将由与此行线相连的列线的电平决定。列线的电平如果为低,则行线电平为低;列线的电平如果为高,则行线的电平亦为高。将行、列线信号配合起来并做适当的处理,才能确定闭合键

47、的位置。6. 答:先对P1 口高四位送低电平,读取P1 口低四位的值;再对P1 口低四位送低电平,读取P1 口高四位的值, 将两次读到的值组合在一起就得到了按键的特征码,在根据特征码查找键值。KEYIN: MOV P1,#0FH ;反转读键MOV A,P1 ANL A,#0FH MOV B,A 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 12 页,共 19 页学而不思则惘,思而不学则殆MOV P1,#0F0H MOV A,P1 ANL A,#0F0H ORL A,B CJNE A,#0FFH,KEYIN1 RET ;未按键KEYIN1: MOV

48、 B,A ;暂存特征码MOV DPTR,#KEYCOD ;指向特征码表MOV R3,#0FFH ;顺序码初始化KEYIN2: INC R3 MOV A,R3 MOVC A,A+DPTR CJNE A,B,KEYIN3 MOV A,R3 ;找到,取顺序码RET KEYIN3: CJNE A,#0FFH ,KEYIN2 ;未完,再查RET ;已查完, 未找到, 以未按键处理KEYCOD: DB 0E7H,0EBH,0EDH,0EEH ;特征码表DB 0D7H,0DBH,0DDH,0DEH DB 0B7H,0BBH,0BDH,0BEH DB 77H,7BH,7DH,7EH 7. 答: (1)编程扫描

49、方式:当单片机空闲时,才调用键盘扫描子程序,反复的扫描键盘,等待用户从键盘上输入命令或数据,来响应键盘的输入请求。( 2)定时扫描工作方式:单片机对键盘的扫描也可用定时扫描方式,即每隔一定的时间对键盘扫描一次。(3)中断工作方式:只有在键盘有键按下时,才执行键盘扫描程序并执行该按键功能程序,如果无键按下,单片机将不理睬键盘。8. 答: DB0-DB7 :数据线,单向传输,由单片机输入给打印机。STB(STROBE) :数据选通信号。在该信号的上升沿,数据线上的8 位并行数据被打印机读入机内锁存。BUSY :打印机忙状态信号。 当该信号有效 (高电平) 时,表示打印机正忙于处理数据。此时, 单片

50、机不得使STB信号有效,向打印机送入新的数据。ACK :打印机的应答信号。低电平有效,表明打印机已取走数据线上的数据。ERR:出错信号。当送入打印机的命令格式出错时,打印机立即打印1 行出错信息,提示出错。在打印出错信息之前。该信号线出现一个负脉冲,脉冲宽度为30us。单片机与打印机相连时,分为直接相连(图10-27)和通过扩展的并行I/O 口 82C55 连接(图10-28) 。直接相连时 (图 10-27) ,打印机在输入电路中有锁存器,在输出电路中有三态门控制,。没有读、写信号,只有握手线、BUSY (或) ,用一根地址线来控制写选通信号STB 和读取BUSY 引脚状态。图10-28 所

51、示为通过扩展的并行I/O 口 82C55 连接的打印机接口电路。采用查询法, 即通过读与82C55 的 PC0 脚的相连的BUSY 状态,来判断送给打印机的一个字节的数据是否处理完毕。也可用中断法(BUSY 直接与单片机的引脚相连)。9答:本程序采用外部中断来进行数据打印,先打印一个数据,当BUSY 线从高电平变成低电平时,在打印下一个数据ORG 0000H LJMP MAIN ORG 0003H LJMP IN ORG 0030H MAIN: SETB EX0 ;允许外部中断SETB IT0 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 13

52、页,共 19 页学而不思则惘,思而不学则殆SETB EA MOV R0,#7FH ;控制口地址MOV A,#81H ;控制字MOVX R0,A MOV R1,#20H ;数据区首地址MOV R2,#19 ;计数器MOV A,R1 ;打印内容MOV R0,#7CH ;A 口地址MOVX R0,A MOV R0,#7FH MOV A,#0EH MOVX RO,A ;PC70 MOV A,#0FH MOVX R0,A ;PC7=1 SJMP $ IN: DJNZ R2,EX ;20 个数据都结束了吗?INC R1 ;指向下一个数据MOV A,R1 MOV R0,#7CH MOVX R0,A MOV

53、R0,#7FH MOV A,#0EH MOVX RO,A MOV A,#0FH MOVX R0,A EX: RETI 第 11 章AT89 S51 单片机与D/A 转换器、 A/D 转换器的接口参考答案1答:由运算放大器构成的I/V 转换电路2答:同步3答: (1)错, D/A 转换器也要考虑“ 转换速度 ” 或“ 转换时间 ” 问题,即建立时间(转换时间);(2)对;(3)错,是 D/A 转换器的分辨率; (4)对。4. 答: DA 转换器的主要技术指标如下:分辨率: DA 转换器的分辨率指输入的单位数字量变化引起的模拟量输出的变化,是对输入量变化敏感程度的描述。建立时间:建立时间是描述DA

54、 转换速度快慢的一个参数,用于表明转换速度。其值为从输入数字量到输出达到终位误差 (12)GB(最低有效位 )时所需的时间。转换精度:理想情况下,精度与分辨率基本一致,位数越多精度越高。严格讲精度与分辨率并不完全一致。只要位数相同,分辨率则相同但相同位数的不同转换器精度会有所不同。当 DAC 为二进制12 位,满量程输出电压为5V 时,分辨率为1.22 mV 5. 答: AD 转换器的两个最重要指标:(1) 转换时间和转换速率-转换时间A D 完成一次转换所需要的时间。转换时间的倒数为转换速率。(2) 分辨率 -A D 转换器的分辨率习惯上用输出二进制位数或BCD 码位数表示。6. 答:量化误

55、差是由于有限位数字且对模拟量进行量化而引起的;最大的量化误差为0.195%;精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 14 页,共 19 页学而不思则惘,思而不学则殆7. 答:目前应用较广泛的主要有以下几种类型:逐次逼近式转换器、双积分式转换器、-式AD 转换器。逐次逼近型AD 转换器: 在精度、速度和价格上都适中,是最常用的AD 转换器件。双积分A D 转换器:具有精度高、抗干扰性好、价格低廉等优点,但转换速度慢,近年来在单片机应用领域中也得到广泛应用。- 式 AD 转换器:具有积分式与逐次逼近式ADC 的双重优点,它对工业现场的串模干扰具

56、有较强的抑制能力,不亚于双积分ADC ,它比双积分 ADC 有较高的转换速度。与逐次逼近式ADC 相比,有较高的信噪比,分辨率高,线性度好,不需要采样保持电路。8. 答:对 DAC 来说,分辨率反映了输出模拟电压的最小变化量。而对于ADC 来说,分辨率表示输出数字量变化一个相邻数码所需输入模拟电压的变化量。量化误差是由ADC 的有限分辨率而引起的误差,但量化误差只适用于ADC ,不适用于DAC 。精度与分辨率基本一致,位数越多精度越高。严格讲精度与分辨率并不完全一致。只要位数相同,分辨率则相同。但相同位数的不同转换器,精度可能会有所不同,例如由于制造工艺的不同。9 答:接口电路可参见图11-2

57、0。参考程序如下:MAIN :MOV R0,#20H MOV R1,#00H MOV R2,#00H MOV R3,#50 MOV R8,#08H LOOP:MOV DPTR, #7FF8H LOOP1: MOVX DPTR,A MOV R6,#0A H DELAY : NOP NOP NOP DJNZ R6,DELAY MOVX A,DPTR INC DPTR MOV R2,DPL MOV DPH,R0 MOV DPL,R1 MOVX DPTR,A INC DPTR MOV R0,DPH MOV R1,DPL MOV DPH,#7FH MOV DPL,R2 DJNZ R7,LOOP1 LCA

58、LL DELAY1M ;延时 1 分钟(子程序另外编写)DJNZ R3,LOOP 第 12 章单片机的串行扩展技术参考答案1答:系统连接简单:I2C 总线系统的基本结构如图12-7。 I2C 总线系统直接与具有I2C 总线接口的各种扩展器件(如存储器、I/O 芯片、 A/D 、D/A、键盘、显示器、日历/时钟)连接。 I2C精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 15 页,共 19 页学而不思则惘,思而不学则殆总线对各器件寻址采用纯软件的寻址方法,无需片选线的连接,这样就大大简化了总线数量,系统各部件之间的连接只需两条线。数据传输速率较高:

59、在标准I2C 普通模式下,数据的传输速率为100kbit/s,高速模式下可达400kbit/s。2答:I2C 总线的起始信号和终止信号都由主机发出,在起始信号产生后,总线就处于占用状态;在终止信号产生后,总线就处于空闲状态。由图 12-9 见起始信号和终止信号的规定。(1)起始信号 ( S) 。在 SCL 线为高电平期间,SDA 线由高电平向低电平的变化表示起始信号,只有在起始信号以后,其他命令才有效。(2)终止信号 ( P) 。在 SCL 线为高电平期间,SDA 线由低电平向高电平的变化表示终止信号。随着终止信号的出现,所有外部操作都结束。3答:无论I2C 总线上的数据传输方向由寻址字节中的

60、数据传输方向位规定:寻址字节器件地址引脚地址方向位DA3 DA2 DA1 DA0 A2 A1 A0 R/ =1,表示主机接收(读) 。R/ =0,表示主机发送(写) 。4答:单片机对I2C 总线中的器件寻址采用软件寻址,主机在发送完起始信号后,立即发送寻址字节来寻址被控的从机,寻址字节格式如题3 所示。 7 位从机地址即为“DA3 、 DA2 、DA1、DA0”和“ A2 、A1、A0” 。其中 “DA3 、DA2、DA1 、DA0”为器件地址,是外围器件固有的地址编码,器件出厂时就已经给定。“A2 、A1、A0”为引脚地址,由器件引脚A2、A1、A0 在电路中接高电平或接地决定(见图12-1

61、2) 。5答: I2C 总线数据传送时,传送的字节数(数据帧)没有限制,每一字节必须为8 位长。数据传送时,先传送最高位,每一个被传字节后面都须跟1 位应答位(一帧数据共9 位) ,如图12-10。I2C 总线在传送每一字节数据后都须有应答信号A,A 信号在第9 个时钟位上出现,A信号对应的时钟由主机产生。这时发方须在该时钟位上使SDA 线处于高电平, 以便收方在这一位上送出低电平的应答信号A。由于某原因收方不对主机寻址信号应答时,例如接收方正在进行其他处理而无法接收总线上的数据时,必须释放总线,将数据线置为高电平,而由主机产生一个终止信号以结束总线的数据传送。当主机接收来自从机的数据时,接收

62、到最后一个数据字节后,必须给从机发送一个非应答信号( ) ,使从机释放数据总线,以便主机发送一个终止信号,从而结束数据的传送。6答:依照下面的数据传送格式:S 从机地址0 A 数据 A/ Sr 从机地址r 1 A 数据P 依次调用依照上述数据传送格式的12.5.2 小节中的各子程序。第 13 章AT89S51 单片机的应用设计与调试参考答案1答: A错; B错; C对; D错(最小系统不能直接测量模拟信号)。2答:用户样机是以AT89S51 单片机为核心的应用系统,没有对单片机中的程序进行检错调试的手段,也无法发现程序运行中的设计硬件的问题,也无法进行软件的开发(如编辑、汇编、调试程序等) ,

63、 因此,必须借助某种开发工具-仿真开发系统所提供的开发手段来解决上述问题。3答:仿真开发系统由哪几部分组成? 目前国内大多使用通用机的仿真开发系统。主要由PC 机、在线仿真器组成,有的还包含有用于程序烧录的编程器,在加上与上述配套的编辑软件、仿真调试软件,程序烧录软件等。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 16 页,共 19 页学而不思则惘,思而不学则殆此外还有独立型仿真器。该类仿真器采用模块化结构,配有不同外设,如外存板、打印机、键盘/显示器等,用户可根据需要选用。尤其在工业现场进行程序仿真调试时,往往没有PC 机的支持,这时使用独立

64、型仿真器也可进行仿真调试工作,只不过要输入机器码,稍显麻烦一些。至于软件仿真开发工具Proteus 软件是一种完全用软件手段对单片机应用系统进行仿真开发的。软件仿真开发工具与用户样机在硬件上无任何联系。不能进行用户样机硬件部分的诊断与实时在线仿真。4答:调试过程见图13-13,4 个步骤。(1)输入用户源程序:用户使用编辑软件源程序输入到PC 机中,并保存在磁盘上。(2)汇编并检查语法错误:在PC 机上,利用汇编程序对用户源程序进行汇编,直至语法错误全部纠正为止。(3)动态在线调试:对用户的源程序进行调试。要先把在线仿真器的仿真插头插入用户样机的单片机插座中(图13-12) ,进行在线仿真调试

65、,利用仿真开发系统提供单步、设置断点等调试手段,来进行系统的调试。纠正软件逻辑上的问题,或排除硬件上的故障。(4)将调试完毕的用户程序通过程序烧写器,固化在程序存储器中。5答:由于软件仿真开发工具Proteus 软件是一种完全用软件手段对单片机应用系统进行仿真开发的。不能进行用户样机硬件部分的诊断与实时在线仿真。因此在系统的开发中,一般是先用 Proteus仿真软件设计出系统的硬件电路,编写程序,然后在Proteus 环境下仿真调试通过。然后依照仿真的结果,完成实际的硬件设计。再将仿真通过的程序烧录到编程器中,然后安装到用户样机硬件板上去观察运行结果,如果有问题,再连接硬件仿真器去分析、调试。

66、6答:在每块印刷电路板的电源输入端跨接的电容应为一个10100F的大容量电解电容(如体积允许, 电容量大一些更好)和一个 0.010.1 F的非电解电容。 用于去除干扰中的高频干扰和低频干扰,并接大电容为了去掉低频干扰成分,并接小电容为了去掉高频干扰部分。7答:光电耦合的主要优点是能有效抑制尖峰脉冲以及各种噪声干扰,从而使过程通道上的信噪比大大提高。因为在工业现场的数据采集或实时控制中,过程通道的输入输出信号线和控制线多,且长度达几百米或几千米,因此不可避免地将干扰引入单片机系统。消除或减弱过程通道的干扰主要采用光电隔离技术。所谓光电隔离采用光电耦合器可以将单片机与前向、后向以及其他部分切断电

67、路的联系,能有效地防止干扰从过程通道进入单片机(见图13-14) 。8答:对于单片机应用系统中的具有较大电感量的元件或设备,诸如继电器、电动机、电磁阀等。当电感回路的电流被切断时,会产生很大的反电势而形成噪声干扰。这种反电势甚至可能击穿电路中晶体管之类的器件,反电势形成的噪声干扰能产生电磁场,对单片机应用系统中的其它电路产生干扰。如果通过电感线圈的是直流电流,可采用如下措施加以抑制:(1)可在线圈两端并联二极管和稳压管,如图(a) 所示。图 (a)由二极管和稳压管构成的反电势抑制电路图(b) 由电阻和二级管组成的反电势抑制电路。在稳定工作时,并联支路被二极管D 阻断而不起作用;当三极管T 由通

68、道变为截止时,在电感线圈两端产生反电势e。此电势可在并联支路中流通,因此 e的幅值被限制在稳压管DZ 的工作电压范围之内,并被很快消耗掉,从而抑制了反电势的干扰。使用时DZ 的工作电压应选择得比外加电源高些。如果把稳压管换为电阻,同样可以达到抑制反电势的目的,如图(b)所示,因此也适用于直流驱动线圈的电路。在这个电路中,电阻的阻值范围可以从几欧姆到几十欧姆。阻值太小,反电势衰减得慢;而阻值太大又会增大反电势的幅值。(2)反电势抑制电路也可由电阻和电容组成,如图(c)所示。适当选择R、C 图(c) 由电阻和电容组成的抑制电路精选学习资料 - - - - - - - - - 名师归纳总结 - -

69、- - - - -第 17 页,共 19 页学而不思则惘,思而不学则殆参数,也能获得较好的耗能效果。这种电路不仅适用于交流驱动的线圈,也适用于直流驱动的线圈。(3)反电势抑制电路不但可以接在线圈的两端,也可以接在开关的两端,例如继电器,接触器等部件在操作时,开关会产生较大的火花,必须利用RC 电路加以吸收,如图( d) ,一般 R 取 12K,C 取 2.24.7 F 。图(d) 接在开关的两端的反电势抑制电路9答:数字地通常有很大的噪声而且电平的跳跃会造成很大的电流尖峰,对模拟地有较大的影响,会引起模拟电路产生误差。所以正确的接法是,必须将所有的模拟地和数字地分别相连,然后模拟(公共)地与数

70、字(公共)地仅在一点上相连接,且地线应尽量加粗,如图13-17。在 ADC 和 DAC 电路中, 尤其要注意地线的正确连接,否则会引起ADC 和 DAC 转换结果的不准确。由于ADC 、DAC 芯片都提供了相应独立的模拟地和数字地引脚,一定要把模拟地引脚和数字地引脚尽可能短的相连。然后再与模拟地尽可能短的连接。10答:(1)电源去耦已经在第 6 题中介绍,就是在印刷电路板的电源输入端跨接退耦电容。跨接的电容应为一个10100F的大容量电解电容 (如体积允许, 电容量大一些更好)和一个 0.010.1 F 的非电解电容。(2)集成芯片去耦每个集成芯片都应安置一个0.01F的瓷片去耦电容, 去耦电

71、容必须安装在本集成芯片的Vcc 和GND 线之间,否则便失去了抗干扰作用。如遇到印刷电路板空隙小装不下时,可每4 10 个芯片安置一个110F高频阻抗特别小的钽电容器。对于抗噪声能力弱,关断电流大的器件和ROM 、RAM 存储器,应在芯片的电源线Vcc 和地线( GND )间接入去耦的瓷片电容。11答: (1)在印制板中留下无用的空白铜箔层,可充当发射天线或接收天线,可把就近它们接地。 (2)走线不要有分支,可避免在线路条在传输高频信号导致反射干扰或发生谐波干扰。12答:常见的软件滤波方法有(1)算术平均滤波法:一般适用于具有随机干扰的信号的滤波。(2)滑动平均滤波法:对周期性干扰有良好的抑制

72、作用,平滑度高,灵敏度低;但对偶然出现的脉冲性干扰的抑制作用差。(3)中位值滤波法:能有效地克服因偶然因素引起的波动干扰。对温度、液位等变化缓慢的被测参数能收到良好的滤波效果。但对流量、速度等快速变化的参数一般不宜采用此法。 (4)去极值平均值滤波法:算术平均与滑动平均滤波法,在脉冲干扰比较严重的场合,干扰将会“ 平均 ” 到结果中去,故上述两种平均值法不易消除由于脉冲干扰而引起的误差,这时可采用去极值平均值滤波法。去极值平均值滤波法类似于体育比赛中的去掉最高、最低分,再求平均。13答: (1)指令冗余:当单片机系统受干扰时,PC 中由于干扰发生错误,会产生“ 乱飞 ” 。当乱飞到某双字节指令

73、,若取指令时刻落在操作数上,误将操作数当作操作码,程序有可能出错。若乱飞到三字节指令,出错概率更大,这时可在双字节指令和三字节指令后插入两个字节以上的NOP 指令,可保护其后的指令不被拆散,这称为指令冗余。(2)软件陷阱:就是一条引导指令“LJMP ERP ”,强行将乱飞的程序引向一个指定的地址入口标号“ERP ” ,在那里有一段专门对程序出错进行处理的程序。为加强其捕捉效果,一般还在它前面加两条NOP 指令。14答:无论是 AT89S51 单片机片内集成的“ 看门狗 ” 还是专门的硬件“ 看门狗 ” 电路, 原理都是使用一个计数器来不断计数,监视程序的运行。当计数器启动运行后,为防止计数器的

74、不必要溢出,应定期性地把WDT 计数器清0,以保证其不溢出。当单片机的程序“ 跑飞 ” 或陷入 “ 死循环” 时,也就不能定时地把看门狗计数器清0。当看门狗计数器值计满溢出时,将在 AT89S51 的RST 引脚上输出一个正脉冲使AT89S51 单片机复位, 在系统的复位入口0000H 处安排一条跳向出错处理程序段的指令或重新从头执行程序,从而使程序摆脱“ 跑飞 ” 或“ 死循环 ” 状态。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 18 页,共 19 页学而不思则惘,思而不学则殆15答:当系统掉电或供电电压过低时,有时需要保护RAM 中的重要

75、内容,这时可使用微处理器监控器芯片中的“ 掉电保护 ” 功能,即给单片机接上备用电池,微处理器监控器芯片会在掉电时自动为单片机系统提供电源,从而保护了RAM 中的重要内容。第 14 章单片机 C 语言程序设计基础参考答案1答: C51 在标准 C 的基础上,作了以下扩充:(1)数据类型的不同。51 系列单片机包含位操作空间和丰富的位操作指令,因此Keil C51 与ANSI C 相比又扩展了4 种类型,以便能够灵活地进行操作。(2)头文件。生产51 系列单片机的厂家有多个,它们的差异在于内部资源如定时器、中断、I/O 等数量以及功能的不同,而对于使用者来说,只需要将相应的功能寄存器的头文件加载

76、在程序内,就可实现它们所具有的功能。因此,Keil C51 系列的头文件集中体现了各系列芯片的不同资源及功能。(3)数据存储类型的不同。标准C 最初是为通用计算机设计的,在通用计算机中只有一个程序和数据统一寻址的内存空间,而51 系列单片机有片内、外程序存储器,还有片内、外数据存储器。 标准 C 并没有提供这部分存储器的地址范围的定义。此外, 对于 AT89C51 单片机中大量的特殊功能寄存器也没有定义。(4)标准 C 没有处理单片机中断的定义。(5)库函数有较大不同。标准C 的库函数中有一些库函数可继续使用部分库函数不适合于嵌入式处理器系统,因此它们被排除在Keil C51 之外,例如库函数

77、printf 和 scanf,在标准 C 中,这两个函数通常用于屏幕打印和接收字符,而在Keil C51 中,它们主要用于串行口数据的收发。(6)51 单片机的硬件资源有限,C51 的编译系统不允许太多的程序嵌套。其次,标准C 所具备的递归特性不被Keil C51 支持。但是从数据运算操作、程序控制语句以及函数的使用上来说,Keil C51 与标准 C 几乎没有什么明显的差别。 如果程序设计者具备了有关标准C 的编程基础, 只要注意Keil C51 与标准 C 的不同之处,并熟悉AT89S51 单片机的硬件结构,就能够较快地使用Keil C51 编程。2. 答:略。3. 答:略。4. 答:略。5. 答:可参考例14-8,将波形数据输出从零开始不断增1 到达最大值后不断减1,回零后再不断增 1 到达最大值后不断减1,从而重复不断发出三角波波形的数据。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 19 页,共 19 页

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号