单片机原理及应用 课后答案张毅刚,彭喜元高等教育出版社.docx

上传人:小飞机 文档编号:5076807 上传时间:2023-06-02 格式:DOCX 页数:30 大小:107.40KB
返回 下载 相关 举报
单片机原理及应用 课后答案张毅刚,彭喜元高等教育出版社.docx_第1页
第1页 / 共30页
单片机原理及应用 课后答案张毅刚,彭喜元高等教育出版社.docx_第2页
第2页 / 共30页
单片机原理及应用 课后答案张毅刚,彭喜元高等教育出版社.docx_第3页
第3页 / 共30页
单片机原理及应用 课后答案张毅刚,彭喜元高等教育出版社.docx_第4页
第4页 / 共30页
单片机原理及应用 课后答案张毅刚,彭喜元高等教育出版社.docx_第5页
第5页 / 共30页
亲,该文档总共30页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《单片机原理及应用 课后答案张毅刚,彭喜元高等教育出版社.docx》由会员分享,可在线阅读,更多相关《单片机原理及应用 课后答案张毅刚,彭喜元高等教育出版社.docx(30页珍藏版)》请在三一办公上搜索。

1、第1章单片机概述参考答案1. 答:微控制器,嵌入式控制器2. 答:CPU、存储器、I/O 口、总线3. 答:C4. 答:B5. 答:微处理器、微处理机和CPU它们都是中央处理器的不同称谓,微处理器芯片本 身不是计算机。而微计算机、单片机它们都是一个完整的计算机系统,单片机是集成在一个 芯片上的用于测控目的的单片微计算机。嵌入式处理器一般意义上讲,是指嵌入系统的单片机、DSP、嵌入式微处理器。目前多 把嵌入式处理器多指嵌入式微处理器,例如ARM7、ARM9等。嵌入式微处理器相当于通用 计算机中的CPU。与单片机相比,单片机本身(或稍加扩展)就是一个小的计算机系统,可 独立运行,具有完整的功能。而

2、嵌入式微处理器仅仅相当于单片机中的中央处理器。为了满 足嵌入式应用的特殊要求,嵌入式微处理器虽然在功能上和标准微处理器基本是一样的,但 在工作温度、抗电磁干扰、可靠性等方面一般都做了各种增强。6. 答:MCS-51系列单片机的基本型芯片分别:8031、8051和8071。它们的差别是在片 内程序存储器上。8031无片内程序存储器、8051片内有4K字节的程序存储器ROM,而8751 片内有集成有4K字节的程序存储器EPROM。7. 答:因为MCS-51系列单片机中的“MCS”是Intel公司生产的单片机的系列符号, 而51系列单片机是指世界各个厂家生产的所有与8051的内核结构、指令系统兼容的

3、单片机。8. 答:相当于MCS-51系列中的87C51,只不过是AT89S51芯片内的4K字节Flash 存储器取代了 87C51片内的4K字节的EPROM。9. 单片机体积小、价格低且易于掌握和普及,很容易嵌入到各种通用目的的系统中,实 现各种方式的检测和控制。单片机在嵌入式处理器市场占有率最高,最大特点是价格低,体 积小。DSP是一种非常擅长于高速实现各种数字信号处理运算(如数字滤波、FFT、频谱分析 等)的嵌入式处理器。由于对其硬件结构和指令进行了特殊设计,使其能够高速完成各种复 杂的数字信号处理算法。广泛地用于通讯、网络通信、数字图像处理,电机控制系统,生物 信息识别终端,实时语音压解

4、系统等。这类智能化算法一般都是运算量较大,特别是向量运 算、指针线性寻址等较多,而这些正是DSP的长处所在。与单片机相比,DSP具有的实现 高速运算的硬件结构及指令和多总线,DSP处理的算法的复杂度和大的数据处理流量以及 片内集成的多种功能部件更是单片机不可企及的。嵌入式微处理器的基础是通用计算机中的CPU,它的地址总线数目较多能扩展较大的 存储器空间,所以可配置实时多任务操作系统(RTOS)。RTOS是嵌入式应用软件的基础 和开发平台。正由于嵌入式微处理器能运行实时多任务操作系统,所以能够处理复杂的系统 管理任务和处理工作。因此,广泛地应用在移动计算平台、媒体手机、工业控制和商业领域 (例如

5、,智能工控设备、ATM机等)、电子商务平台、信息家电(机顶盒、数字电视)以及 军事上的应用。10. 广义上讲,凡是系统中嵌入了 “嵌入式处理器”,如单片机、DSP、嵌入式微处理 器,都称其为“嵌入式系统”。但多数人把“嵌入”嵌入式微处理器的系统,称为“嵌入式 系统”。目前“嵌入式系统”还没有一个严格和权威的定义。目前人们所说的“嵌入式 系 统”,多指后者。第2章AT89S51单片机的硬件结构参考答案1. 答:AT89S51单片机的片内都集成了如下功能部件:(1) 1个微处理器(CPU);(2) 128个数据存储器(RAM)单元;(3) 4K Flash程序存储器;(4) 4个8位可编 程并行I

6、/O 口 (P0 口、P1 口、P2 口、P3 口); (5) 1个全双工串行口;(6) 2个16位定 时器/计数器;(7) 1个看门狗定时器;(8) 一个中断系统,5个中断源,2个优先级;(9) 25个特殊功能寄存器(SFR),(10) 1个看门狗定时器。2. 答:当ea脚为高电平时,单片机读片内程序存储器(4K字节Flash)中的内容,但 在PC值超过0FFFH(即超出4K字节地址范围)时,将自动转向读外部程序存储器内的程序; 当EA脚为低电平时,单片机只对外部程序存储器的地址为0000HFFFFH中的内容进行读 操作,单片机不理会片内的4K字节的Flash程序存储器。3. 答:2ps4.

7、 答:1个机器周期等于12个时钟振荡周期。5. 答: 64K程序存储器空间中有5个特殊单元分别对应于5个中断源的中断服务程序入口地址,见下表:表5个中断源的中断入口地址入口地址中断源0003H外部中断0 (INT0)000BH定时器0 (T0)0013H外部中断1 (INT1)001BH定时器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的单元可作为工作寄

8、存器区。13. 答:(A)错;(B)错;(C)错;(D)错。14. 答:(C)。15. 答:PC; PC。16. 答:64K字节。17. P0 口每位可驱动8个LSTTL输入,而P1、P2、P3 口的每一位的驱动能力,只有 P0 口的一半。当P0 口的某位为高电平时,可提供400 A的电流;当P0 口的某位为低电平(0.45V)时,可提供3.2mA的灌电流,如低电平允许提高,灌电流可相应加大。所以,任 何一个口要想获得较大的驱动能力,只能用低电平输出。18. 答:按下复位按钮。19. 答:(A)对;(B)对;(C)错;(D)错。20. 答:(A)对;(B)对;(C)对;(D)错。第3章AT89

9、S51的指令系统参考答案1. 答:(1)错(2)错(3)对(4)错(5)错(6)错(7)错(8)对(9)错(10)对(11)对(12)错。2. 答:(A)对(8)对(C)错(D)错。3. 答:A, PC, DPTR。4. 答:只能使用直接寻址方式。5. 答:操作码,操作数,操作码。6. 答:1031H。7. 答:程序,数据。8. 答:地址。9. 答:A的内容与B的内容互换。10. 答:(A) =50H,( SP) =50H,( 51H) =30H,( 52H) =50H,( PC)=5030H11. 答:(A) ANL A, #87H(B) ANL A, #0C3H(C) ORL A, #0C

10、H12. 答:(A) =0CBH。13. 答:(A) =00H,( R3) =0AAH。14. 答:(DPH) =3CH,( DPL) =5FH,( SP) =50H15. 答:(SP) =62H,(61H) =30H,(62H) =70H。16. 答:MOV R7, APUSH AccMOV A,BMOVX DPTR, A17. 答:( D)。18. 答:( C)。19. 答:基本型的51子系列单片机,由于其片内RAM的地址范围为00H7FH,而80H FFH为特殊功能寄存器区,而对特殊功能寄存器寻址,只能使用直接寻址方式。对片内RAM 寻址,当使用寄存器间接寻址是采用R0或R1作为间接寻址

11、的,因此R0或R1的内容不能 超过7FH。增强型的52子系列单片机,片内RAM的地址范围为00HFFH,因此作为间接寻址寄 存器的R0或R1的内容就不受限制。第4章AT89S51汇编语言程序的设计与调试参考答案1. 答:伪指令是程序员发给汇编程序的命令,只有在汇编前的源程序中才有伪指令,即 在汇编过程中的用来控制汇编过程的命令。所谓“伪”是体现在汇编后,伪指令没有相应的机器代码产生。常用伪指令及其功能如下:ORG (ORiGin)汇编起始地址命令;END (END of assembly)汇编终止命令;EQU(EQUate) 标号赋值命令;DB(Define Byte)定义数据字节命令;DW(

12、Define Word)定 义数据字命 令;DS(Define Storage)定义存储区命令;BIT位定义命令2. 答:手工汇编:通过查指令的机器代码表(表3-2),逐个把助记符指令“翻译”成机器代 再进行调试和运行。这种人工查表“翻译”指令的方法称为“手工汇编”。机器汇编:借 助于微型计算机上的软件(汇编程序)来代替手工汇编。通过在微机上运行汇编程序,把 汇编语言源程序翻译成机器代码。反汇编:将二进制的机器码程序翻译成汇编语言源程序的过程称为“反汇编”。3. 答:从1000H开始的各有关存储单元的内容(16进制)如下:4D 41 494E 12 34 30 0000 70 787F E4

13、F6 D8 FD75 81 07024. 在编写子程序时应注意以下问题:(1) 子程序的第一条指令前必须有标号。(2) 主程序调用子程序,有如下两条子程序调用指令: 绝对调用指令ACALL addr11。被调用的子程序的首地址与绝对调用指令的下一条 指令的高5位地址相同,即只能在同一个2KB区内。 长调用指令LCALL addr16。addr16为直接调用的目的地址,被调用的子程序可放 置在64KB程序存储器区的任意位置。(3) 子程序结构中必须用到堆栈,用来保护断点和现场保护。(4) 子程序返回时,必须以RET指令结束。(5) 子程序可以嵌套,但要注意堆栈的冲突。5.答:参考程序如下:MOV

14、 A,45HANL A#0FHORL A#0FH MOV 45H,A6.答:A=80H,SP=40H,(41H) =50H,(42H) =80H,PC=8050H 7.答:参考程序如下:START: MOV R0,#30HMOV R2,#20HLOOP: MOV A,R0CJNEA,#0AAH,NEXTMOV51H,#01HLJMPEXITNEXT:INCR0DJNZ R2,LOOP MOV 51H,#00H EXIT: RET8. 答:参考程序如下:STARTMOV41H,#0MOVR0, #20HMOVR2, #20HLOOP:MOVA,R0JNZNEXTINC41HNEXT:INCR0D

15、JNZ R2, LOOP RET9. 答:参考程序如下:ORG 0100HMOV R2, #20H要比较的数据字节数 MOV A , #21H MOV R1 , A DEC R2 MOV A , R1LOOP:MOV R3,ADEC R1 CLR C SUBB A, R1 JNC LOOP1 MOV A, R1 SJMP LOOP2LOOP1:MOV A,R3LOOP2:DJNZ R2, LOOPMOV R0,A RET10. 答:(1) SP=SP+1=61H(61H) =PC的低字节=03HSP=SP+1=62H(62H)=PC 的高字节=20H(2) PC=3456H(3) 可以(4)

16、2KB = 2048 Byte11. 答:可对程序做如下修改:ORG0100HDEL:MOVR7, #200DEL1:MOVR6,#12;将原来的立即数125改为123DEL2:DJNZR6, DEL2NOP;增加的指令DJNZR7, DEL1RET程序修改后的延时时间为:1+(1+123*2+1+2)*200+2=50003us=50.003ms第5章AT89S51的中断系统参考答案1. 答:0013H; 001BH2. 答:串行口中断;外部中断13. 答:RETI指令在返回的同时清除相应的优先级触发器,以允许下次中断,而RET指令则没有这个操作。除了这一点两条指令不同外,其它操作都相同。4

17、. 答:D5. 答:在一个单一中断的系统里,AT89S51单片机对外部中断请求的响应时间总是在 38个机器周期之间。在下述三种情况下,AT89S51将推迟对外部中断请求的响应:(1) AT89S51正在处理同级或更高优先级的中断。(2) 所查询的机器周期不是当前正在执行指令的最后一个机器周期。(3) 正在执行的指令是RETI或是访问IE或IP的指令。如果存在上述三种情况之一, AT89S51将丢弃中断查询结果,将推迟对外部中断请求 的响应。6. 答:D7. 答:PC、PC、程序存储器8. 答:参考程序段如下:SETB IT1SETB EX1SETB EA9. 答:(A)10. 答:一个中断源的

18、中断请求被响应,必须满足以下必要条件:(1)总中断允许开关接通,即IE寄存器中的中断总允许位EA=1。(2)该中断源发出中断请求,即该中断源对应的中断请求标志为“1”。(3)该中断源的中断允许位=1,即该中断被允许。(4)无同级或更高级中断正在被服务。11. 答:(A)、(C)、(D)12. 答:参见电路如图5-10,参考程序如下:ORG0000HLJMPMAINORG0013HLJMPINT_EX1ORG0030HMAIN: CLRIT0;米用电平触发,低电平有效中断SETBEX1;允许外部中断1SETBEA;插入一段用户程序WAIT: MOV PCON,#01H ;单片机进入休眠方式等待中

19、断NOPLJMP WAIT;判断是不是3号中断;跳转到3号中断处理程 序;判断是不是2号中断;跳转到2号中断处理程 序序;跳转到1号中断处理程 序中断返回;以下为外部中断1服务子程序INT_EX1 jb P1.2,NEXT1 :LJMP INT_IR3NEXT1: JB P1.1,NEXT2LJMP INT_IR2NEXT2: LJMP INT_IR1ORG 1000HINT_IR3:相应中断处理程序RETI ORG 1100HINT_IR2 :相应中断处理程序RETI ;中断返回ORG 1200HINT_IR1:相应中断处理程序RETI ;中断返回第6章AT89S51的定时/计数器参考答案1

20、. 答:(A)对;(B)错;(C)错;(D)错;2. 答:因为机器周期:T = 12 = 12 = 4 ( s )W七 fosc = 3 1。6 = 4( s)所以定时器/计数器工作方式。下,其最大定时时间为T = 213 T = 213 4 106 = 8.192 (ms)-同样可以求得方式1下的最大定时时间为262.144ms;方式2下的最大定时时间为 1024ms。3. 答:定时/计数器作定时时,其计数脉冲由系统振荡器产生的内部时钟信号12分频后 提供。定时时间与时钟频率和定时初值有关。4. 答:由于确认1次负跳变要花2个机器周期,即24个振荡周期,因此外部输入的 计数脉冲的最高频率为系

21、统振荡器频率的1/24。5. 答:定时器/计数器T0在计数和定时工作完成后,均采用中断方式工作。除了第一次 计数工作方式设置在主程序完成外,后面的定时或计数工作方式分别在中断程序完成,用一 标志位识别下一轮定时器/计数器T0的工作方式。参考程序如下:ORG0000HLJMPMAINORG000BHLJMPIT0PMAIN: MOVTMOD,#06H;定时器/计数器T0为计数方式2MOVTL0,#156;计数100个脉冲的初值赋值MOVTH0,#156SETBGATE;打开计数门SETBTR0;启动T0,开始计数SETBET0;允许T0中断SETBEA;CPU开中断CLRF0 ;设置下一轮为定时

22、方式的标志位WAIT: AJMPWAITIT0P: CLREA;CPU关中断JBF0,COUNT;F0=1,转计数方式设置MOVTMOD,#00H;定时器/计数器T0为定时方式0MOVTH0,#0FEH;定时1ms初值赋值MOVTL0,#0CHSETBEARETICOUNT: MOVTMOD,#06HMOVTL0,#156SETBEARETI6. 定时器/计数器的工作方式2具有自动恢复初值的特点,适用于精确定时,比答:如波特率的产生。7. 答:根据题意,从P1.0输出的矩形脉冲的高低电平的时间为10:1,则高低电平 的 时间分别为363.63 ns和36.37 us。如果系统采用6MHz晶振的

23、话,Tcy =2us,因此高 低电 平输出取整,则约为364us和36 ns。参考程序如下:ORG0000HLJMPMAINORG000BHLJMPIT0PMAIN: MOVTMOD,#02H;定时器/计数器T0为定时方式2MOVTL0,#4AH;定时364 n s初值赋值SETBTR0;启动T0,开始计数SETBET0;允许T0中断SETBEA;CPU开中断SETB P1.0WAIT: AJMP WAITIT0P CLR EA :CLR P1.0MOV R0,#9DLYDJNZ R0,DLY :MOV TL0,#4AHSETB P1.0SETB EA;关中断;延时36 us;定时364 us

24、初值赋值RETI8. 答:方法1,在第一个定时器的中断程序里关闭本定时器的中断程序,设置和打开 另一个定时器;在另一个定时器的中断程序中关闭本定时中断,设置和打开另一个定时器。 这种方式的定时时间为两个定时器定时时间的和。方法2, 一个作为定时器,在定时中断后产生一个外部计数脉冲(比如由P1.0接INT(产 生),另一个定时器工作在计数方式。这样两个定时器的定时时间为一个定时器的定时时间 乘以另一个定时器的计数值。9. 答:由T1(P3.5)口控制定时器T1的启动和关闭。10. 答:采用方式1定时工作方式。最大脉冲宽度为131.072ms。11. 答:将P1.1的输入脉冲接入INT0,即使用T

25、0计数器完成对P1.1 口的脉冲计数。 参考程序如下:ORG0000HLJMPMAINORG000BHLJMPIT0PMAIN: JNBP1.0,MAINMOVTMOD,#05H;定时器/计数器T0为计数方式1SETBTR0;启动T0,开始计数SETBET0;允许T0中断SETBEA;CPU开中断WAIT: JBP1.2,WAITCLREACLRTR0MOVR1,TH0MOV R0,TL0AJMP $IT0P: INC R2RETI12.答:THx与TLx (x=0,1)是由特殊功能寄存器构成的计数器,其内容可以随时用指 令更改,更改后的新值是立即刷新。但在读THx、TLx的值时,应该先读TH

26、x值,后读 TLx,再读THx。若两次读得THx相同,则可确定读得的内容正确。若前后两次读得的 THx有变 化,再重复上述过程。第7章AT89S51的串行口参考答案1. 答:方式1。2. 答:相等的。3. 答:A.对;B.对;C.错;D.对;E.对。4. 答:C5. 答:C6. 答:当接收方检测到RXD端从1到0的跳变时就启动检测器,接收的值是3次连续 采样,取其中2次相同的值,以确认是否是真正的起始位的开始,这样能较好地消除干扰引 起的影响,以保证可靠无误的开始接受数据。7. 答:串行口有4种工作方式:方式0、方式1、方式2、方式3;有3种帧格式,方 式2和3具有相同的帧格式;方式0的发送和

27、接收都以fosc/12为固定波特率,方式1的波特率=2smod/32X定时器T1的溢出率方式2的波特率=2smod/64 X fosc方式3的波特率=2smod/32X定时器T1的溢出率8. 答:字符B”的ASCII码为“42H”,帧格式如下:9. 答:因为定时器/计数器在方式2下,初值可以自动重装,这样在做串口波特率发生 器设置时,就避免了执行重装参数的指令所带来的时间误差。设定时器T1方式2的初值为X,计算初值X可采用如下公式:波特率=2% 12(25晶10. 答:经计算,计数初值为FAH,初始化程序如下:ANLTMOD,#0F0H;屏蔽高4 位ORLTMOD,#20H;控制字MOVTH1

28、,#0FAH;写入计数初值MOVTL1,#0FAHMOVSCON,#40H11. 答:见7.3节的介绍。12. 答:见7.5.3小节的介绍13. 答:串口每秒钟传送的字符为:1800/60=30个字符/秒所以波特率为:30个字符/秒X10位/个字符=300b/s14. 答:串行口的方式0为同步移位寄存器输入输出方式,常用于外接移位寄存器, 以扩展并行I/O 口,一般不用于两个MCS-51之间的串行通信。该方式以fosc/12的固定波 特率从低为位到高位发送或接受数据。15. 答:直接以TTL电平串行传输数据的方式的缺点是传输距离短,抗干扰能力差。 因此在串行传输距离较远时,常采用RS-232C

29、、RS-422A和RS-485标准串行接口。主要是 对传输的电信号不断改进,如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。9. 答:本题主要考察对外部存储器的读、写操作,只要记住正确使用MOVX指令

30、就可以了。编程思路:首先读取2001H的值,保存在寄存器A中,将寄存器A的高四位和低四 位互换,再屏蔽掉低四位然后将寄存器A的值保存到30H中,然后再读取2002H的值,保 存在寄存器A中,屏蔽掉高四位,然后将寄存器A的值与30H进行或运算,将运算后的结 果保存在2002H中。ORG 0000HMAIN:MOVDPTR,;设置数据指针的初值#2001HMOVXA,DPTR;读取2001H的值SWAPAANLA,#0F0H;屏蔽掉低四位MOV30H,A;保存AINCDPTR;指针指向下个MOVXA,DPTR;读取2002H的值ANLA,#0FH;屏蔽掉高四位ORLA,30H;进行拼装MOVXDP

31、TR, A;保存到2002HEND10.答:本题主要考察对外部数据块的写操编程时只要注意循环次数和MOVX作;令的使用就可以了。指ORG0000HMAIN:MOVA, #0;送预置数给AMOVR0, #0FFH;设置循环次数MOVDPTR,#4000H ;设置数据指针的初值LOOP:MOVXDPTR,a;当前单元清零INCDPTR;指向下一个单元DJNZR0, LOOP;是否结束END11.答:因为控制信号线的不同:外扩的RAM芯片既能读出又能写入,所以通常都有读写控制引脚,记为OE*和WE*。外扩RAM的读、写控制引脚分别与AT89S51的RD*和 WR*引脚相连。外扩的EPROM在正常使用

32、中只能读出,不能写入,故EPROM芯片没有写入控制引脚,只有读出引脚,记为 OE*,该引脚与AT89S51单片机的PSEN*相连。12 .答:图中采用了译码法。4片地址分别为0000H-3FFFH、4000H-7FFFH、 8000H-BFFFH、C000H-FFFFH。13. 答:(1) 参见图8-20或图8-21,去掉一片2764。(2) 指出该应用系统程序存储器空间和数据存储器空间各自的地址范围。14. 答:1)A组跨接端子的内部正确连线图2)B组跨接端子的内部正确连线图注意:答案不唯一,还有其他连接方法,也可满足题目要求。第9章AT89S51扩展I/O接口的设计参考答案1. 答:(A)

33、 错,81C55具有地址锁存功能;(B) 错,在81C55芯片中,引脚IO/M*、A2、A1、A0决定端口地址和RAM单元 编址;(C) 错,82C55不具有三态缓冲器;(D) 错,82C55的B 口只可以设置成方式0和方式1。2. 答:I/O端口简称I/O 口,常指I/O接口电路中具有端口地址的寄存器或缓冲器。I/O 接口是指单片机与外设间的I/O接口芯片;I/O接口功能:(1)实现和不同外设的速度匹配; (2)输出数据缓存;(3)输入数据三态缓冲。3. 答:3种传送方式:(1)同步传送方式:同步传送又称为有条件传送。当外设速度 可与单片机速度相比拟时,常常采用同步传送方式。(2)查询传送方

34、式:查询传送方式又称 为有条件传送,也称异步传送。单片机通过查询得知外设准备好后,再进行数据传送。异 步传送的优点是通用性好,硬件连线和查询程序十分简单,但是效率不高。(3)中断传送方式:中断传送方式是利用AT89S51本身的中断功能和I/O接口的中断功能来实现I./O数 据的传送。单片机只有在外设准备好后,发出数据传送请求,才中断主程序,而进入与外 设进行数据传送的中断服务程序,进行数据的传送。中断服务完成后又返回主程序继续执 行。因此,中断方式可大大提高工作效率。4. 答:两种。(1)独立编址方式:独立编址方式就是I/O地址空间和存储器地址空间分开 编址。独立编址的优点是I/O地址空间和存

35、储器地址空间相互独立,界限分明。但却需要设 置一套专门的读写I/O的指令和控制信号。(2)统一编址方式:这种方式是把I/O端口的寄 存器与数据存储器单元同等对待,统一进行编址。统一编址的优点是不需要专门的I/O指令, 直接使用访问数据存储器的指令进行I/O操作。AT89S51单片机使用的是I/O和外部数据 存储器RAM统一编址的方式。5. 答:82C55通过写入控制字寄存器的控制字的最高位来进行判断,最高位为1时, 为方式控制字,最高位为0时,为C 口按位置位/复位控制字。6. 答:本题主要考察对82C55的C 口的操作。其方式控制字的最高位为0时,低四位控装置对C 口置复由题目可知方式控制寄

36、存器的地址为7FFFH。位。;控制字寄存器地址7FFFH送DPTR;将PC7置0;将PC4置1ORG 0100HMAIN: MOV DPTR,#7FFFHMOV A,#0EHMOVX DPTR,AMOV A,#09HMOVX DPTR,AEND7. 答:当外设输入一个数据并送到PA7-PA0上时,输入设备自动在选通输入线stba 向82C55发送一个低电平选通信号,则把PA7-PA0上输入的数据存入PA 口的输入数据缓 冲/锁存器;然后使输入缓冲器输出线IBFA变成高电平,以通知输入设备,82C55的PA 口 已收到它送来的输入数据。82C55检测到联络线stba由低电平变成了高电平、IBFA

37、为1状 态和中断允许触发器INTEA为1时,使输出线INTRA(PC3)变成高电平,向AT89S51发出 中断请求。(INTEa的状态可由用户通过对PC4的置位/复位来控制。AT89S51响应中断 后, 可以通过中断服务程序从PA 口的输入数据缓冲/锁存器读取外设发来的输入数据。当 输入 数据被CPU读走后,82C55撤销INTRA上的中断请求,并使IBFA变为低电平,以通 知输 入外设可以送下一个输入数据。8. 答:81C55的端口有以下几种:命令/状态寄存器、PA 口、PB 口、PC 口、计数器的高8位寄存器与低8位寄存器以及RAM单元。引脚IO/m,A2、A1、A0决定端口地址。TIME

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

39、 DPTR, A;送方式控制字MOV DPTR, #0FF7DH ;PB 口地址送DPTRMOVX A, DPTR;读入开关信息MOV DPTR, #0FF7CH ;PA 口地址送DPTRMOVX DPTR, A;PA 口的内容送PB 口点亮相应的二极管10.答:81C55计数器的初值范围是:3FFFH-2H。当频率为4MHz,初值为3FFFH时,最大定时时间为:0.004096S11.答:将1MHz的脉冲改变为10ms的方波,实际上就是分频。分频前后频率之比为100:1,这样只要将定时器初值设置为64H就可以了。(假设I/O 口地址为7F00H-7F05H)指针指向计数器低8位START:

40、MOVMOVDPTR,#7F04H ;A, #64H;送初值给AMOVXDPTR,AINCDPTR ;;初值送给计数器低8位 指向计数器高8位MOVA, #40H;计数器方波输出MOVXMOVMOVMOVXENDDPTE,ADPTR,#7A00H0;C2H,指向命令/状态口 设定控制字DPTE,A启动计数器第10章AT89S51与键盘、显示器、拨盘、打印机的接口设计参考答案1. 答:A. MAX7219是专用显示器芯片,不用于键盘;B.错:CH451芯片也可用于控 制键盘;C.对:BUSY信号可作为查询信号或中断请求信号使用,但此时信号ack不用; E.错:LED数码管的字型码是可以变的,例如

41、表10-1中的“a”段对应段码字节的最高 位。“dp”段对应段码字节的最低位,字型码就改变了。2. 答:在按键的闭合和断开过程中,由于开关的机械特性,导致了按键抖动的产生。如 果不消除按键的机械抖动,按键的状态读取将有可能出现错误。消除按键抖动一般是采用软 件或硬件去抖。软件去抖的原理:在第一次检测到有键按下时,该键所对应的行线是为低电 平,执行一端延时10ms的子程序后,确认该行线电平是否仍然为低电平,如果仍为低电平, 则确认为该行确实有键按下。3. 答:静态显示时,数据是分开送到每一位LED上的。而动态显示则是数据是同时送 到每一个LED上,再根据位选线来确定是哪一位LED被显示。静态显示

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

43、组合在一起就得到了按键的特征码,在根据 特征码查找键值。KEYIN: MOV P1,#0FH;反转读键MOV A,P1ANL A,#0FHMOVMOVB,AP1,#0F0HMOVA,P1ANLA,#0F0HORLA,BCJNEA,#0FFH,KEYIN1RET;未按键KEYIN1: MOV B,A;暂存特征码MOVDPTR,#KEYCOD;指向特征码表MOVR3,#0FFH;顺序码初始化KEYIN2: INCR3MOVA,R3MOVCA,A+DPTRCJNEA,B,KEYIN3MOVA,R3;找到,取顺序码RETKEYIN3: CJNEA,#0FFH,KEYIN2;未完,再查RET;已查完,未

44、找到,以未按键处理KEYCOD: DB0E7H,0EBH,0EDH,0EEH ;特征码表DB0D7H,0DBH,0DDH,0DEHDB0B7H,0BBH,0BDH,0BEHDB77H,7BH,7DH,7EH7-答:(1)编程扫描方式:当单片机空闲 才调用键盘扫描子程序,反复的扫描键时J,盘,等待用户从键盘上输入命令或数据,来响应键盘的输入请求。(2)定时扫描工作方式:单片机对键盘的扫描也可用定时扫描方式,即每隔一定的时间对键盘扫描一次。(3) 中断工作方式:只有在键盘有键按下时,才执行键盘扫描程序并执行该按键功能程序,如 果无键按下,单片机将不理睬键盘。8. 答:DB0-DB7:数据线,单向传输,由单片机输入给打印机。STB (STROBE):数据 选通信号。在该信号的上升沿,数据线上的8位并行数据被打印机读入机内锁存BUSY: 打印机忙状态信号。当该信号有效(高电平)时,表示打印机正忙于处理数据。此时,单 片机不得使STB信号有效,向打印机送入新的数据。ACK:打印机的应答信号。低电平有 效,表明打印机已取走数据线上的数据ERR :出错信号。当送入打印机的命令格式出错时,打 印机立即打印1行出错信息,提示出错。在打印出错信息之前。该信号线出现一个负脉 冲,脉冲宽度为30us。单片机与打印机相连时,分为直接相连(图10-27)和

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号