单片机原理及接口技术第二版李全利主编课后答案_第1页
单片机原理及接口技术第二版李全利主编课后答案_第2页
单片机原理及接口技术第二版李全利主编课后答案_第3页
单片机原理及接口技术第二版李全利主编课后答案_第4页
单片机原理及接口技术第二版李全利主编课后答案_第5页
已阅读5页,还剩24页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、1第一台计算机的问世有何意义? 答:第一台电子数字计算机ENIAC问世,标志着计算机时代的到来。与现代的计算机相比, ENIAC有许多不足,但它的问世开创了计算机科学技术的新纪元,对人类的生产和生活方式产生了 巨大的影响。 2计算机由哪几部分组成? 答:由运算器、控制器、存储器、输入设备和输出设备组成,运算器与控制器合称CPU 3微型计算机由哪几部分构成? 答:微型计算机由微处理器、存储器和/0接口电路构成。各部分通过地址总线AB、数据 总线(DB和控制总线(CB相连。 4微处理器与微型计算机有何区别? 答:微处理器集成了运算器和控制器(艮CPU ;而微型计算机包含微处理器、存储器和/0 接口

2、电路等。 5什么叫单片机?其主要特点有哪些? 答:在一片集成电路芯片上集成微处理器、存储器、I/O接口电路,从而构成了单芯片微型 计算机,即单片机。单片机主要特点有:控制性能和可靠性高;体积小、价格低、易于产品化; 具有良好的性能价格比。 6微型计算机有哪些应用形式?各适于什么场合? 答:微型计算机有三种应用形式:多板机(系统机)、单板机和单片机。 多板机,通常作为办公或家庭的事务处理及科学计算,属于通用计算机。 单板机, I/O 设备简单,软件资源少,使用不方便。早期主要用于微型计算机原理的教案及 简单的测控系统,现在已很少使用。 单片机,单片机体积小、价格低、可靠性高,其非凡的嵌入式应用形

3、态对于满足嵌入式应用 需求具有独特的优势。目前,单片机应用技术已经成为电子应用系统设计的最为常用技术手段。 7当前单片机的主要产品有哪些?各有何特点? 答:多年来的应用实践已经证明,80C51的系统结构合理、技术成熟。因此,许多单片机芯 片生产厂商倾力于提高80C51单片机产品的综合功能,从而形成了 80C51的主流产品地位,近年 - 1 - / 29 来推出的与80C5镰容的主要产品有: ATME公司融入Flash存储器技术推出的AT89系列单片机; Philips公司推出的80C51 80C552系列高性能单片机; 华邦公司推出的 W78C51W77C5系列高速低价单片机; ADI公司推出

4、的ACU C8xx系列高精度ADC单片机; LG公司推出的GMS90/9系列低压高速单片机; Maxim公司推出的DS89C42高速(50MIPS单片机; Cygnal公司推出的C8051系列高速SO(单片机等。 8简述单片机的开发过程。 答:系统需求分析,硬件方案设计,软件编程,仿真调试,实际运行。 9单片机应用系统开发方法有哪些新方法? 答:在系统编程QSP)技术,在应用编程(AP)技术。 章2 80C51 的结构和原理 1. 80C5单片机在功能上、工艺上、程序存储器的配置上有哪些种类? 答:功能上分为基本型和增强型; 工艺上分为HMO工艺和CHMOS艺; 在片内程序存储器的配置上有掩膜

5、OMEPROMFIash、无片内程序存储器形式。 2. 80C51 单片机的存储器的组织采用何种结构?存储器地址空间如何划分?各地址空间的 地址范围和容量如何?在使用上有何特点? 答:采用哈佛结构,在物理上设计成程序存储器和数据存储器两个独立的空间80C51基本型 单片机片内程序存储器为4KB地址范围是0000H-0FFFH用于存放程序或常数;片内数据存储器 为128字节RAM地址范围是00H-7FH用于存放运算的中间结果、暂存数据和数据缓冲;另外在 80H-FF还配有21个SFR 3. 80C5单片机的P0P:口在结构上有何不同?在使用上有何特点? 答:作为通用I/O 口时,P0 P1、P2

6、和P3都是准双向口。 P0可以作为地址/数据总线,此时是一个真正的双向口 ;P2 口可以作为地址线的高8位;P3 口是双功能口,每条口线还具有不同的第二功能。 另外,P0口的驱动能力为8个TTL负载,而其它口仅可驱动4个TTL负载。 4. 如果80C51单片机晶振频率分别为6 MHz 11.0592 MH、12MHZ寸,机器周期分别为多 少? 答:机器周期分别为2皿,1.085, 1 as。 5. 80C51单片机复位后的状态如何?复位方法有几种? 答:复位后,PC内容为0000H P0 口P3 口内容为FFH SP内容为07H SBUF内容不定, IP、IE和PCO的有效位为0,其余的特殊功

7、能寄存器的状态均为)0H 复位方法一种是上电复位,另一种是上电与按键均有效的复位。 6. 80C5单片机的片内、片外存储器如何选择? 答:80C51的EA引脚为访问片内、片外程序存储器的选择端。访问片内、片外数据存储器需 要采用不同的指令加以区分。 7. 80C51单片机的PSV寄存器各位标志的意义如何? 答:CY进位、借位标志。有进位、借位时CY=1否则CY=0 AC辅助进位、借位标志(高半字节与低半字节间的进位或借位); F0:用户标志位,由用户自己定义; RS1 RS0当前工作寄存器组选择位; OV溢出标志位。有溢出时OV=1否则OV=0 P:奇偶标志位。存于ACC中的运算结果有奇数个1

8、时P=1否则P=0 8. 80C51单片机的当前工作寄存器组如何选择? 答:当前工作寄存器组的选择由特殊功能寄存器中的程序状态字寄存器SWF RS1 RS0来 决定。 9. 80C51单片机的控制总线信号有哪些?各信号的作用如何? 答:RST/VPD复位信号输入引脚卩备用电源输入引脚;ALE/PROG :地址锁存允许信号输出引 脚/编程脉冲输入引脚;EA/VPP内外存储器选择引脚片内EPROM或 FlashROM编程电压输入 引脚;PSEN :外部程序存储器选通信号输出引脚。 10. 80C5单片机的程序存储器低端的几个特殊单元的用途如何? 答:0000H单片机复位入口地址;0003H外部中断

9、0的中断服务程序入口地址;000BH定 时/计数器0溢出中断服务程序入口地址;0013H外部中断1的中断服务程序入口地址;001BH 定时7计数器1溢出中断服务程序入口地址;0023H串行口的中断服务程序入口地址 章380C51的指令系统 1. 80C51系列单片机的指令系统有何特点? 答:执行时间短。1个机器周期指令有64条,2个机器周期指令有45条,而4个机器周期指 令仅有2条(即乘法和除法指令); 指令编码字节少。单字节的指令有49条,双字节的指令有45条,三字节的指令仅有17条; 位操作指令丰富。这是80C5单片机面向控制特点的重要保证。 2. 80C51单片机有哪几种寻址方式?各寻址

10、方式所对应的寄存器或存储器空间如何? 答:80C51单片机的寻址方式有七种。即:寄存器寻址、直接寻址、寄存器间接寻址、立即寻 址、基址寄存器加变址寄存器变址寻址、相对寻址和位寻址。 这些寻址方式所对应的寄存器和存储空间如下表所示 序 号 寻址方 式 寄存器或存储空间 1 寄存器 .寻址 1 寄存器R0R7A、AB dptRq C(布尔累加器) 2 寻址寻 片内和Am低布尔字加器Sfr 3 址存器 间接寻 片内 RA(R0R1 SP 片外 RA(R0R1 4 立即寻 DPOM 5 址址寻 址一 ROMADPTRAPC 6 相对寻 ROMPC当前值的+127 -128字节) 7 位寻址 可寻址位(

11、内部 RAM20H2单元的位和部分 SFR的位) 3. 访问特殊功能寄存器SFR可以采用哪些寻址方式? 答:直接寻址和位寻址方式。 4. 访问内部RAM单元可以采用哪些寻址方式? 答:直接寻址、寄存器间接寻址和位寻址方式。 5. 访问外部RAM单元可以采用哪些寻址方式? 答:寄存器间接寻址。 6访问外部程序存储器可以采用哪些寻址方式? 答:立即寻址、变址寻址和相对寻址方式。 7.为什么说布尔处理功能是80C51单片机的重要特点? 答:单片机指令系统中的布尔指令集、存储器中的位地址空间与PL中的位操作构成了片内的 布尔功能系统,它可对位( bit )变量进行布尔处理,如置位、清零、求补、测试转移

12、及逻辑 “与”、“或”等操作。在实现位操作时,借用了程序状态标志器PS)中的进位标志Cy作为 位操作的“累加器”。 (2)内部RAM单元60H的内容传送到寄存器R2 (3)外部RAM单元1000H的内容传送到内部RAM单元60H (4)外部RAM单元1000H的内容传送到寄存器R2 (5)外部RAM单元1000H的内容传送到外部RAM单元2000H 答:(1) MOV A,R0 MOV R1,A (2)MOV R2,60H (3) MOV DPTR,#1000H MOVX A,DPTR MOV 60H,A (4) MOV DPTR,#1000H MOVX A,DPTR MOV R2,A (5)

13、 MOV DPTR,#1000H MOVX A,DPTR MOV DPTR,#2000H MOVX DPTR, A 11. 若(R1) =30H (A) =40H (30H =60H (40H =08H试分析执行下列程序段后上述 各单元内容的变化。 MOV A,R1 MOV R,1 40H MOV 40H,A MOV R1,#7FH 答:(RD =7FH (A) =60H (30H) =08H (40H) =60H 12. 若(A) =E8H(R0 =40H (R1 =20H (R4 =3AH(40H =2CH(20H =0FH 试 写出下列各指令独立执行后有关寄存器和存储单元的内容?若该指令

14、影响标志位,试指出 CY、 AC和OV的值。 (1) MOV A R0 2)ANL 40H,#0FH (3)ADD A,R4 (4) SWAP A (5) DEC R1 (6) XCHD A,R1 答:(1)(A)=2CH ( 2)( 40H) =0CH (3) (A) =22H,(CY) =1,(AC) =1,(OV) =0 (4) (A) =8EH (5) (20H) =0EH,P=1 (6) (A) =EFH,(20) =08H 13. 若(50H =40H试写出执行以下程序段后累加器A寄存器RO及内部RAM勺40H 41H 42H单元中的内容各为多少? MOV A ,5OH MOV R

15、O,A MOV A ,#OOH MOV RO,A MOV A ,#3BH MOV 41H,A MOV 42H,41H 答:(A) =3BH (RO =40H (40H =00H (41H =3BH(42H =3BH 14. 试用位操作指令实现下列逻辑操作。要求不得改变未涉及的位的内容。 (1)使 ACC.(置位; ( 2)清除累加器高4位; (3)清除 ACC.,3 ACC.,4 ACC.5,ACC.6。 答:(1) SETB ACC.O 2)ANL A,#0FH (3)ANL A,#87H 15. 试编写程序,将内部RAM的20H 21H 22H三个连续单元的内容依次存入2FH 2EH和 2

16、DH单元。 答:MOV 2FJH20H MOV 2EH, 21H MOV 2D,H22H 16. 试编写程序,完成两个16位数的减法:7F4DH2B4EH结果存入内部RAM的30H和31H 单元,30H单元存差的高8位,31H单元存差的低8位。 答: CLR CY MOV 30,H#7FH MOV 31,H#4DH MOV R,0 #31H MOV A, R0 SUBB A, #4E MOV R, 0A ;保存低字节相减结果 DEC R0 MOV A, R0 SUBB A, #2BH MOV R, 0A ;保存高字节相减结果 17. 试编写程序,将R1中的低4位数与R2中的高4位数合并成一个8

17、位数,并将其存放在 R1中。 答: MOV A, R2 ANL A, #0F0H ORL R1, A 18.试编写程序,将内部RAM勺20H 21H单元的两个无符号数相乘,结果存放你2 R3中, R2中存放高8位,R3中存放低8位。 答:MOV A20H MOV B, 21H MUL AB MOV R,3A MOV R,2B 19.若(CY =1,(P1) =10100011,(P3 =011011008试指出执行下列程序段后,CY P1 口及P3 口内容的变化情况。 MOV P1.3, C MOV P1.4, C MOV C, P1.6 MOV P3.6, C MOV C, P1.0 MOV

18、 P3.4, C 答:(CY =1,(P1) =10111011, (P3 =00111100B 章 4 80C51 的汇编语言程序设计 1. 80C5单片机汇编语言有何特点? 答:汇编语言结构紧凑、灵活,汇编成的目标程序效率高,具有占存储空间少、运行速度 快、实时性强等优点。它是面向机器的语言,对于单片机硬件的操作直接、方便,有利于初学者 对单片机结构的认知。 但它与高级语言相比移植性不好、编程复杂、对编程人员的基础要求高。 2. 利用80C5单片机汇编语言进行程序设计的步骤如何? 答:一、任务分析 首先,要对单片机应用系统的设计目标进行深入分析,明确系统设计任务:功能要求和技术 指标。然后

19、对系统的运行环境进行调研。这是应用系统程序设计的基础和条件。 二、算法设计 经过任务分析和环境调研后,已经明确的功能要求和技术指标可以用数学方法(或模型)来 描述,进而把一个实际的系统要求转化成由计算机进行处理的算法。并对各种算法进行分析比 较,并进行合理的优化。 三、流程描述 程序的总体构建。先要确定程序结构和数据形式,资源分配和参数计算等。然后根据程序运 行的过程,规划程序执行的逻辑顺序,用图形符号将程序流程绘制在平面图上。应用程序的功能 通常可以分为若干部分,用流程图将具有一定功能的各部分有机地联系起来。 流程图可以分为总流程图和局部流程图。总流程图侧重反映程序的逻辑结构和各程序模块之

20、间的相互关系;局部流程图反映程序模块的具体实施细节。 3常用的程序结构有哪几种?特点如何? 答:顺序程序:无分支、无循环结构的程序,其执行流程是依指令在存储器中的存放顺序进 行的; 分支程序:可以改变程序的执行顺序; 循环程序:按某种控制规律重复执行的程序,控制一部分指令重复执行若干次,以便用简短 的程序完成大量的处理任务。 4子程序调用时,参数的传递方法有哪几种? 答:利用累加器或寄存器;利用存储器;利用堆栈。 5什么是伪指令?常用的伪指令功能如何? 答:伪指令是汇编程序能够识别并对汇编过程进行某种控制的汇编命令。常用的伪指令包 括: ORG功能是向汇编程序说明下面紧接的程序段或数据段存放的

21、起始地址; END功能是结束汇编; DB功能是从标号指定的地址单元开始,在程序存储器中定义字节数据; DW/功能是从标号指定的地址单元开始,在程序存储器中定义字数据空间; EQ,U 功能是将表达式的值或特定的某个汇编符号定义为一个指定的符号名; BIT,功能是将位地址赋给指定的符号名。 6. 设被加数存放在内部RA啲20H 21H单元,加数存放在22H 23H单元,若要求和存放在 24H 25H中,试编写出16位无符号数相加的程序(采用大端模式存储)。 答:程序如下: ORG 0000H MOV R0, 21H MOV R1, 23H MOV A,R0 ADD A,R1 MOV 25H,A D

22、EC R0 DEC R1 MOV A,R0 ADDC A,R1 MOV 24H,A SJMP $ END 7. 编写程序,把外部RAM中1000H101F的内容传送到内部RAM的 30H4F中。 答:ORG 0000H MOV DPTR,#1000H MOV R0,#30H MOV R7,#32 LOOP:MOVX A,DPTR MOV R0,A INC R0 INC DPTR DJNZ R7,LOOP RET 8. 编写程序,实现双字节无符号数加法运算,要求(R0R1 + (R6R7 -(60H61H。 答:ORG 0000H MOV A,R1 ADD A,R7 MOV 61H,A MOV

23、A,R0 ADDC A,R6 MOV 60H,A SJMP $ END 9. 若80C51的晶振频率为6MH,试计算延时子程序的延时时间。 DELAY:MOV R7,#0F6H LP:MOV R6,#0FAH DJNZ R6,$ DJNZ R7,LP RET 答:延时时间:2卩s*1+( 1+2*250+2 *246)+2+2=0.247486秒(含调用指令2个机器周 期) 10. 在内部RAM的30H37单元存有一组单字节无符号数。要求找出最大数存TBIG单元。 试编写程序实现。 答: ORG 0000H BIG DATA 2FH ONE DATA 2AH TWO DATA 2BH STAR

24、T:MOV R7,#7 MOV R0,#30H LOOP:MOV A,R0 MOV ONE,A INC R0 MOV TWO,R0 CLR C SUBB A,R0 JC NEXT MOV R0,ONE DEC R0 MOV R0,TWO INC R0 NEXT:DJNZ R7,LOOP MOV BIG,37H SJMP $ END 比较次数 。ONEb, TW大继续比下一对数 。ON大放后面(交换) 。TWO、放前面 11.编写程序,把累加器A中的二进制数变换成3位BC码,并将百、十、个位数分别存放 在内部RA啲50H 51H 52H中。 单元 org 0 MOV 52H,#0 MOV 51H

25、,#0 MOV 50H,#0 MOV A,#0FDh LCALL DCDTH SJMP $ DCDTH:MOV R7,#8 MOV R0,A。暂存于 R0 LOOP:CLR C MOV A,R0 RLC A MOV R0,A MOV R1,#51H 。 MOV A,R1 。 ADDC A,R1 。 DA A 。 MOV R1,A 。 DEC R1 MOV A,R1 ADDC A,R1 DA A MOV R1,A DJNZ R7,LOOP INC R1。50H已是结果,R1指向51H 51H单元需拆分 MOV A,#00H XCHD A,R1 MOV 52H,A MOV A,R1 SWAP A

26、MOV R1,A RET END 12.编写子程序,将R1中的2个十六进制数转换为ASCII码后存放在R3和R4中 答: ORG 0 MOV R1,#5BH MOV A,R1 ANL A,#0F0H SWAP A ACALL ASCII MOV R3,A MOV A,R1 ANL A, #0FH ACALL ASCII MOV R4, A SJMP $ ASCII:PUSH ACC CLR C SUBB A, #0AH POP ACC JC LOOP ADD A, #07H LOOP: ADD A, #30H RET END 13. 编写程序,求内部RAM中 50H59十个单元内容的平均值,并

27、存放在5AH单元。 答: ORG 0000H MOV R7,#10 MOV R0,#50H MOV B,#10 CLR C CLR A LOOP:ADDC A,R0 INC R0 DJNZ R7,LOOP DIV AB MOV 5AH,A SJMP $ END 14. 如图4.10所示,编制程序实现:上电后显示P,有键按下时显示相应的键号0” 7”。 答:实现程序如下: TEMP EQU 30H JMP START ORG 0100H START:MOV SP,#5FH MOV P0,#8CH 正序显示 MOV P3,#0FFH 输入方式 CLR CY NOKEY:MOV A,P3 CPL A

28、 JZ NOKEY 无键按下 MOV TEMP,P3 有键按下 CALL D10ms MOV A,P3 CJNE A,TEMP,NOKEY 。去抖动 MOV R2,#0 键号计数器复位 MOV A,TEMP LP:RRC A JNC DONE INC R2 SJMP LP DONE:MOV A,R2 MOV DPTR,#CODE_P0 MOVC A,A+DPTR MOV P0,A JMP NOKEY D1ms:M0V R4,#249 DL:NOP NOP DJNZ R4,DL DJNZ R5,D1ms RET CODE_PO: DB 0C0H,0F9H,0A4H,0B0H,99H,92H,82

29、H,0F8H DB 80H,90H,88H,83H,0C6H,0A1H,86H,8EH END 章5 80C51的中断系统及定时计数器 1.80C51有几个中断源?各中断标志是如何产生的?又是如何复位的CPJ向应各中断时, 其中断入口地址是多少? 答:5个中断源,分别为外中断NT0和inF1 TO和T1溢出中断、串口中断。 电平方式触发的外中断标志与引脚信号一致;边沿方式触发的外中断响应中断后由硬件自动 复位。 T0和T1, CPU向应中断时,由硬件自动复位。 RI和TI,由硬件置位。必须由软件复位。 另外,所有能产生中断的标志位均可由软件置位或复位。 各中断入口地址:int0 0003H T

30、0-000BH inTi0013H TI001BH RI 和 TI 0023H 2. 某系统有三个外部中断源1、2、3,当某一中断源变低电平时便要求CPU处理,它们的优 先处理次序由高到低为3、2、1,处理程序的入口地址分别为2000H 2100H 2200H试编写主程 序及中断服务程序(转至相应的入口即可)。 答:将3个中断信号经电阻线或,接厂1。 LJMP MAIN ORG 00013H LJMP ZDFZ ORG 0040H MAIN:SETB EA SETB EX1 SJMP $ 0RG 0200H ZDFZ:PUSH PSW PUSH ACC JB P1.0,DV0 JB P1.1,

31、DV1 JB P1.2,DV2 INRET:POP ACC POP PSW RETI ORG 2000H DV0: JMP INRET ORG 2100H DV1: JMP INRET ORG 2200H DV2: 3. 外部中断源有电平触发和边沿触发两种触发方式,这两种触发方式所产生的中断过程有何 不同?怎样设定? 答:当ITO=O时,INTO为电平触发方式。电平触发方式时,CPU在每个机器周期的S5P2采样 硕引脚电平,当采样到低电平时,置E0=1向CPU请求中断;采样到高电平时,将E0清0。 在电平触发方式下,CPU向应中断时,不能自动清除E0标志。 电平触发方式时,外部中断源的有效低电

32、平必须保持到请求获得响应时为止,不然就会漏掉; 在中断服务结束之前,中断源的有效的低电平必须撤除,否则中断返回之后将再次产生中断。该 方式适合于外部中断输入为低电平,且在中断服务程序中能清除外部中断请求源的情况。 当IT0=1时,丽为边沿触发方式。边沿触发方式时,CPl在每个机器周期的S5P2采样INTO 引脚电平,如果在连续的两个机器周期检测到肝0引脚由高电平变为低电平,即第一个周期采样 到iNT0=1,第二个周期采样至歸=0,则置IE0=1,产生中断请求。在边沿触发方式下,CPU向 应中断时,能由硬件自动清除E0标志。 边沿触发方式时,在相继两次采样中,先采样到外部中断输入为高电平,下一个

33、周期采样到 为低电平,则在IE0或IE1中将锁存一个逻辑1。若CPU暂时不能响应,中断申请标志也不会丢 失,直到CPU向应此中断时才清0。另外,为了保证下降沿能够被可靠地采样到,丽和斤1引脚 上的负脉冲宽度至少要保持一个机器周期(若晶振频率为2MH,为1微秒)。边沿触发方式适合 于以负脉冲形式输入的外部中断请求。 4. 定时/计数器工作于定时和计数方式时有何异同点? 答:定时7计数器实质是加1计数器。 不同点:设置为定时器模式时,力m计数器是对内部机器周期计数1个机器周期等于12个 振荡周期,即计数频率为晶振频率的1/12)。计数值乘以机器周期就是定时时间。设置为计数器 模式时,外部事件计数脉

34、冲由T0或T1引脚输入到计数器。在每个机器周期的S5P2期间采样T0 T1引脚电平。当某周期采样到一高电平输入,而下一周期又采样到一低电平时,则计数器加, 更新的计数值在下一个机器周期的S3P期间装入计数器。 方式0: 13位计数器; 方式1: 16位计数器; 方式2:具有自动重装初值功能的8位计数器; 方式3: TO分为两个独立的8位计数器,T1停止工作。 5. 定时/计数器的4种工作方式各有何特点? 答:方式0位13位计数器,由TLO的低5位(高3位未用)和TH0的8位组成。TLO的低5 位溢出时向TH(进位,TH0溢出时,置位TCO中的TFO标志,向CPI发出中断请求。 计数初值计算的公

35、式为:X=213-N 方式1的计数位数是16位,由TLO作为低8位、THO乍为高8位,组成了 16位加1计数器。 计数个数与计数初值的关系为:X=216- N 方式2为自动重装初值的8位计数方式THC为8位初值寄存器。当TLO计满溢出时,由硬件 使TFO置1,向CPI发出中断请求,并将TH0中的计数初值自动送入TLQ TLO从初值重新进行加 1计数。周而复始,直至TR0二才会停止。计数个数与计数初值的关系为:X=28-N 方式3只适用于定时计数器TO,定时器T1处于方式3时相当于TR1=0,停止计数。方式3 时,TO分成为两个独立的8位计数器TLO和THO TLO使用TO的所有控制位。当TLO

36、计数溢出 时,由硬件使TFO置 1,向CPI发出中断请求。而TH(固定为定时方式(不能进行外部计数),并 且借用了T1的控制位TR1 TF1因此,THO的启、停受TR1控制,THO的溢出将置位TF1 6. 要求定时7计数器的运行控制完全由TR1 TRO确定和完全由而、INT1高低电平控制时, 其初始化编程应作何处理? 答:TMO中GATE勺值不同:完全由TR1 TRO确定时GAT为O;完全由而、肝1高低电 平控制时GAT为1。 7当定时/计数器TO用作方式3时,定时7计数器T1可以工作在何种方式下?如何控制T1 的开启和关闭? 答:TO用作方式3时,T1可以工作在方式0、1和2。T1的开启由T

37、R1控制,即TR仁1时, 8.利用定时/计数器TO从P1.0输出周期为1s,脉宽为20ms的正脉冲信号,晶振频率为 12MHz试设计程序 答:采用定时20ms然后再计数1、49次的方法实现。 a、TO工作在定时方式1时,控制字TMO配置: M1M0=01 , GATE=0C/t=0,可取方式控制字为01H; b、计算计数初值X 晶振为12 MHz所以机器周期Tcy为1。 Nkt/ Tcy =20X10_3/1 X10_ 6=20000 16 X=2 Nk65536-20000=45536=4E20H 即应将4EH送入TH1中,20H送入TL1中。 c、实现程序如下: ORG 0000H ajm

38、p main ORG 0030H MAIN:MOV TMOD,#01H MOV TH0,# 4EH MOV TL0,#20H LP0:SETB P1.0 ACALL NT0 CLR P1.0 MOV R7,#49 LP1:ACALL NT0 DJNZ R7,LP1 AJMP LP0 NT0:MOV TH0,# 4EH MOV TL0,#20H 跳转到主程序 设T1工作于方式2 装入循环计数初值 首次计数值 计数49次 SETB TR0 CLR TRO CLR TFO RET END 9.要求从P1.1引脚输出1000H方波,晶振频率为12MHz试设计程序 答:采用TO实现 a、TO工作在定时方

39、式1时,控制字TMO配置: M1M0=01,GATE=OC/t=O,可取方式控制字为01H b、计算计数初值X 晶振为12 MHz所以机器周期Tcy为1八1/1000二伙10T3 _ 3 6 N=t/ Tcy =0.5 X10/1 X10_ =500 X= 216N=65536- 500= 6503= FE0CH 即应将FEH送入TH(中, 0CH送入TL0中。 c、实现程序如下: ORG 0000H ajmp main 。跳转到主程序 ORG 000BH LJMP DVT0 ORG 0030H z T0的中断入口地址 MAIN:MOV TMOD,#01H 。设T0工作于方式2 MOV TH0

40、,# 0FEH 。装入循环计数初值 MOV TL0,#0CH 。首次计数值 SETB ET0 。T0开中断 setb ea 。CPI开中断 SETB TR0 。启动T0 SJMP $ DVT0:CPL P1.1 MOV TH0,# 0FEH MOV TL0,# 0CH SETB TR0 。等待中断 reti end 10. 试用定时7计数器T1对外部事件计数。要求每计数100,就将T1改成定时方式,控制 P1.7输出一个脉宽为10ms的正脉冲,然后又转为计数方式,如此反复循环。设晶振频率为 答:a T1工作在计数方式2时,控制字TMOD配置: M1M0=10 , GATE=0C/t = 1,可

41、取方式控制字为60H T1工作在定时方式1时,控制字TMO配置: M1M0=01 , GATE=OC/t=O,可取方式控制字为10H b、计算初值X: 定时10mS寸: 晶振为12 MHz所以机器周期Tcy为1。 _ 3 6 Nkt/ Tcy =10X10/1 X1O_ =10000 X=216Nk65536-10000= 55536=D8FH 即应将D8H送入TH1中,F0H送入TL1中。 计数100时: N=100 X=28N= 256-100= 156= 9CH c、实现程序如下: ORG 0000H ajmp main ORG 001BH LJMP DVT1 ORG 0030H MAI

42、N:MOV TMOD,#60H MOV TH1,#9CH MOV TL1,#9CH CLR P1.7 SETB ET1 setb ea SETB TR1 SJMP $ 跳转到主程序 T1的中断入口地址 T1工作于计数方式2 装入计数初值 T1开中断 CPUf中断 启动T1 等待中断 DVT1:SETB P1.7 CLR TR1 MOV TMOD,#10H MOV TH1,#0D8H MOV TL1,#0F0H SETB TR1 JNB TF1,$ CLR TF1 CLR TR1 CLR P1.7 MOV TMOD,#60H MOV TH1,#9CH MOV TL1,#9CH SETB ET1 SETB TR1 RETI 。T1工作于定时方式1 。装初值 查询等待10ms T1工作于计数方式2 装初值 T1开中断 启动T1 END 11. 利用定时7计数器T0产生定时时钟由P1 口控制8个指示灯。编一个程序使8个指示灯 依次闪动,闪动频率为1次/秒(

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论