单片机原理及应用第二版张毅刚课后习题答案_第1页
单片机原理及应用第二版张毅刚课后习题答案_第2页
单片机原理及应用第二版张毅刚课后习题答案_第3页
单片机原理及应用第二版张毅刚课后习题答案_第4页
单片机原理及应用第二版张毅刚课后习题答案_第5页
已阅读5页,还剩19页未读 继续免费阅读

下载本文档

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

文档简介

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

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

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

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

5、信息家电(机顶盒、数字电视)以及军事上的应用。10.广义上讲,凡是系统中嵌入了 “嵌入式处理器”,如单片机、DSP嵌入式微 处理器,都称其为“嵌入式系统”。但多数人把“嵌入”嵌入式微处理器的系统, 称为“嵌入式系统”。目前“嵌入式系统”还没有一个严格和权威的定义。目前 人们所说的“嵌入式系统”,多指后者。第2章AT89S51单片机的硬件结构1AT89S5111CPU2 (.答:个微处理器(单片机的片内都集成了如下功能部件:(;) 128RAM 34K Flash448I/OP0()位可编程并行个数据存储器()单元个;(口)程序存储器;(P1P2P3516216/71个看(计数器;)(个口、)口

6、、口、(口); 位定时器)个全双工用行口; 852925SFR(),(门狗定时器;个特殊功能寄存器) 一个中断系统,个中断源,(个优先级;101个看门狗定时器。()24K Flash-) 中的内容,但脚为高电平时,单片机读片内程序存储器(.答:当字节EAPC0FFFH4K 字节地址范围)时,将自动转向读外部程序存储器内的程序;在值超过(即超出0000HFFFFH的内容进行读操脚为低电平时,单片机只对外部程序存储器的地址为当一ea Flash4K程序存储器。作,单片机不理会片内的字节的 22s3.答: 1241个时钟振荡周期。.答:个机器周期等于64K5.个中断源的中断服务程序入001BH定时器

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

8、当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) Xt (B)对(C)错(D)错。3 .答:A, PC, DPTR4 .答:只能使用直接寻址方式。5 .答:操作码,操作数,操作码。6 .答:

9、1031H。7 .答:程序,数据。8 .答:地址。9 .答:A的内容与B的内容互换。10 .答:(A) =50H, (SB =50H, (51H) =30H, (52H) =50H, (PQ = 5030H11 .答:(A) ANL A, #87H(B) ANL A, #0C3H(C) ORL A, #0CH12 .答:(A) =0CBH13 .答:(A) =00H, (R3) =0AAH14 .答:(DPH) =3CH, (DPD =5FH, (SP)=50H15 .答:(SP) =62H, (61H) =30H, (62H) =70H。16 .答:MOV R7, AAcc PUSHAMOV

10、 , BMOVX DPTR A17 .答:(D)。18 .答:(C)。19 .答:基本型的51子系列单片机,由于其片内RAM的地址范围为00H 7FH, 而80HFFH为特殊功能寄存器区,而对特殊功能寄存器寻址,只能使用直接寻址方式。对片内RAM寻址,当使用寄存器间接寻址是采用 R0或R1作为间接寻 址的,因此R0或R1的内容不能超过7FH增强型的52子系列单片机,片内RAM的地址范围为00H FFH,因此作为间接 寻址寄存器的R0或R1的内容就不受限制。第4章AT89S51汇编语言程序的设计与调试1 .答:伪指令是程序员发给汇编程序的命令,只有在汇编前的源程序中才有伪 指令,即在汇编过程中的

11、用来控制汇编过程的命令。 所谓“伪”是体现在汇编后, 伪指令没有相应的机器代码产生。常用伪指令及其功能如下:ORG (ORiGin)汇编起始地址命令;END(END of assembly1编终止命令;EQU (EQUatR 标号赋值命令;DB (Define Byte)定义数据字节命令;DW ( Define Word)定义数 据字命令;DS ( Define Storage定义存储区命令;BIT位定义命令2 .答:手工汇编:通过查指令的机器代码表(表 3-2),逐个把助记符指令“翻译”成机 器代码,再进行调试和运行。这种人工查表“翻译”指令的方法称为“手工汇编”。 机器汇编:借助于微型计算

12、机上的软件(汇编程序)来代替手工汇编。通过在微机 上运行汇编程序,把汇编语言源程序翻译成机器代码。反汇编:将二进制的机器码程序翻译成汇编语言源程序的过程称为“反汇编”3 .答:从1000H开始的各有关存储单元的内容(16进制)如下:4D 41 49 4E 12 34 30 0000 704 .在编写子程序时应注意以下问题:(1)子程序的第一条指令前必须有标号。(2)主程序调用子程序,有如下两条子程序调用指令: 绝对调用指令ACALL addr11被调用的子程序的首地址与绝对调用指令的下 一条指令的高5位地址相同,即只能在同一个2KB区内。 长调用指令LCALL addr16 addU6为直接调

13、用的目的地址,被调用的子程序可放置在64KB程序存储器区的任意位置。(3)子程序结构中必须用到堆栈,用来保护断点和现场保护。(4)子程序返回时,必须以RET指令结束。(5)子程序可以嵌套,但要注意堆栈的冲突。5 .答:参考程序如下:MOV 45H, AANL A #0FHORL A , #0FHMOV 45H, A6 .答:A=80H , SP=40H (41H)=50H, (42H)=80H , PC=8050H7 .答:参考程序如下:START MOV R0,#30HR2,#20H MOVMOV LOOP:A,R0CJNEA,#0AAH,NEXTMOV 51H,#01H LJMP EXIT

14、NEXT: R0 INCDJNZ R2,LOOP 51H,#00H MOV EXIT: RET8 .答:参考程序如下:START MOV 41H,#0R0, #20H MOVMOV R2,#20HLOOP MOV A,R0NEXT JNZINC 41HR0 NEXT INCDJNZ R2, LOOPRET9 .答:参考程序如下:ORG 0100HMOV R2, #20H要比较的数据字节数A , #21HMOV MOV R1 , ADEC R2MOV A , R1LOOP:MOV R3,AR1DECCCLRR1 ASUBB , JNC LOOP1MOV A , R1LOOP2 SJMPA,R3

15、LOOP1: MOVLOOP2:DJNZR2, LOOPMOV R0,ARET10 .答:(1) SP=SP+1=61H (61H尸PC勺低字节=03H(62H尸PC的高字节=20HSP=SP+1=62H(2) PC=3456H(3)不可以(4) 2K氏 2048 Byte11 .答:可对程序做如下修改:ORG 0100HMOV R7, #200 DEL:;将原来的立即数125改为123 MOV DEL1: R6, #123R6, DEL2 DJNZ DEL2:;增加的指令 NOPDJNZ R7, DEL1RET程序修改后的延时时间为:1+(1+123*2+1+2)*200+2=50003us

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

17、P的指令。如果存在上述三种情况之一,AT89S51将丢弃中断查询结果,将推迟对外部中断 请求的响应。6 .答:D7 .答:PG PG程序存储器8 .答:参考程序段如下:SETB IT1EX1 SETBEA SETB9 .答:(A)10 .答:一个中断源的中断请求被响应,必须满足以下必要条件:(1)总中断允许开关接通,即IE寄存器中的中断总允许位 EA=1。(2)该中断源发出中断请求,即该中断源对应的中断请求标志为“1(3)该中断源的中断允许位=1,即该中断被允许。(4)无同级或更高级中断正在被服务。11 .答:(A)、(C)、(D)12 .答:参见电路如图5-10,参考程序如下:ORG 000

18、0HMAINLJMP0013HORGINT_EX1LJMP0030HORG;采用电平触发,低电平有效中断 MAIN: CLR IT0SETB;允许外部中断1 EX1SETB EA ;插入一段用户程序 WAIT: MOV PCON,#01H;单片机进入休眠方式等待中断NOPLJMP WAIT;以下为外部中断1服务子程序INT_EX1 JB P1.2 NEXT1 ;判断是不是 3号中断;灰传到3号中断处理程序LJMP INT_IR3;判断是不是2号中断 NEXT1: JB P1.1, NEXT2;跳转到2号中断处理程序 LJMP INT_IR2 NEXT2: LJMP INT_IR1 ;跳转到1号

19、中断处如序 ORG1000HINT_IR3:相应中断处理程序RETI ;中断返回1100H ORGINT_IR2:相应中断处理程序RETI ;中断返回1200H ORGINT_IR1:相应中断处理程序RETI ;中断返回第6章AT89S51的定时/计数器1 .答:(A)对;(B)错;(C)错;(D)错;2 .答:因为机器周期:1212?J)4(T?cy 6f 10?3osc下,其最大定时时间为0所以定时器/计数器工作方式6?1313)ms.4?0192(?T0?T08cMAX下的最大定时时间为262.144ms下的最大定时时间为;方式2同样可以求得方式 1 1024mso分频/计数器作定时时,

20、其计数脉冲由系统振荡器产生的内部时钟信 号123.答:定时后提供。定时时间与时钟频率和定时初值有关。个振荡周期,因此外部输入的个机器周期,即 24.答:由于确认41次负跳变要花2 1/24。计 数脉冲的最高频率为系统振荡器频率的在计数和定时工作完成后,均采用中断方式工作。除了第一计数器T05.答:定时器/次计数工作方式设置在主程序完成 外,后面的定时或计数工作方式分别在中断程序完成,的工作方式。参考程序如下:用一标志位识别下一轮定时器/计数器T0 ORG 0000HMAIN LJMP 000BH ORGIT0PLJMPMAIN: MOV计数器TMOD,#06H ;定时器/T0为计数方式2 MO

21、V 个脉冲的初值赋值;计数 TL0,#156 100MOVTH0,#156SETB GATE ;打开计数门;启动T0TR0 ,开始计数 SETB;允许ET0 SETB T0中断;SETB CPUFF 中断EACLR F0 ;设置下一轮为定时方式的标志位WAIT: AJMP WAITIT0P: CLR EA ; CPU关中断;F0=1,转计数方式设置 F0,COUNT JBTMOD,#00HMOV ;定时器/ 计数器T0为定时方式0TH0,#0FEH ;定时1msMOV初值赋值MOV TL0,#0CH SETB EA RETICOUNT:TMOD,#06H MOVTL0,#156MOV SETB

22、 EA RETI6 .答:定时器/计数器的工作方式2具有自动恢复初值的特点,适用于精确定时,比如波特率的产生。7 .答:根据题意,从P1.0输出的矩形脉冲的高低电平的时间为10:1 ,则高低 电平的Tcy=2p s,因此高低电晶振的话,3 3 363.63s和36.37s。如果系统采 用6MHz寸间分别为平输出取整,则约为 364仙s和36ps。参考程序如下:ORG 0000HLJMP MAIN000BH ORGIT0P LJMPTMOD,#02H ;定时器/计数器T0为定时方式2 MAIN: MOVMOV初值赋值 TL0,#4AH ;定时364 sSETB ;启动TR0 T0,开始计数;允许

23、 ET0T0SETB中断;CPUEA 开中断 SETBP1.0 SETBWAIT AJMP WAITIT0P: CLR EACLRP1.0 ;关中断R0,#9 MOVR0,DLY ;延时 36 p s DLY DJNZs 初值赋值 TL0,#4AH MOV 364;定时以 SETB P1.0 SETB EARETI8 .答:方法1,在第一个定时器的中断程序里关闭本定时器的中断程序, 设置和 打开另一个定时器;在另一个定时器的中断程序中关闭本定时中断, 设置和打开 另一个定时器。这种方式的定时时间为两个定时器定时时间的和。接P1.0产(比如由一个彳为定时器,2方法,在定时中断后产生一个外部计数脉

24、 冲into生),另一个定时器工作在计数方式。这样两个定时器的定时时间为一个定 时器的定时时间乘以另一个定时器的计数值。9 .答:由TMOD寄存器的D6位“C/T*”来控制定时器T1的启动和关闭。10 .答:采用方式1定时工作方式。最大脉冲宽度为131.072ms。11 .答:将P1.1的输入脉冲接入INT0,即使用T0计数器完成对P1.1 口的脉冲计 数。参考程序如下:ORG 0000HLJMP MAINORG 000BHLJMP IT0PMAIN: JNB P1.0,MAINMOV TMOD,#05H /计数器T0为计数方式1 ;定时器;启动,开始计数 T0SETB TR0中断 T0 ET

25、0 ;允许 SETB SETB EA 开中断 CPUP1.2,WAITWAIT:JB CLR EA CLRTR0 R1,TH0 MOV MOVR0,TL0 AJMP$IT0P:INC R2 RETI12 .答:THx与TLx (x=0,1是由特殊功能寄存器构成的计数器,其内容可以随时 用指令更改,更改后的新值是立即刷新。但在读THx、TLx的值时,应该先读THx 值,后读TLx,再读TH>g若两次读得THx相同,则可确定读得的内容正确。若 前后两次读得的THx有变化,再重复上述过程。第7章AT89S51的串行口1 .答:方式1。2 .答:相等的。3 .答:A. Xt; B. Xt; C.

26、错;D.对;E.对。4 .答:C5 .答:C6 .答:当接收方检测到RXD端从1到0的跳变时就启动检测器,接收的值是 3 次连续采样,取其中2次相同的值,以确认是否是真正的起始位的开始, 这样能 较好地消除干扰引起的影响,以保证可靠无误的开始接受数据。7 .答:用行口有4种工作方式:方式0、方式1、方式2、方式3;有3种帧格 式,方式2和3具有相同的帧格式;方式0的发送和接收都以fosc/12为固定波 特率,smod/32 X定时器T1的溢出率 方式1的波特率=2smod/64 X fosc方式2的波特率 =2smod/32X定时器T1=2的溢出率 方式3的波特率8.答:字符“ B”的ASCI

27、IS 为“42H”,帧格式如下:9.答:因为定时器/计数器在方式2下,初值可以自动重装,这样在做串口波特 率发生器设置时,就避免了执行重装参数的指令所带来的时间误差。设定时器T1方式2的初值为X,计算初值X可采用如下公式:SMODf2 波特率 =osc?)3212(2567X10.答:经计算,计数初值为FAH,初始化程序如下:ANL TMOD,#0F0H ;屏蔽高 4 位;控制字 TMOD,#20HORL;写入计数初值 MOV TH1,#0FAHTL1,#0FAH MOVSCON,#40H MOV11 .答:见7.3节的介绍。12 .答:见7.5.3小节的介绍13 .答:串口每秒钟传送的字符为

28、:1800/60=30个字符/秒所以波特率为:30个字符/秒X 10位/个字符=300b/s14 .答:用行口的方式0为同步移位寄存器输入输出方式, 常用于外接移位寄存 器,以扩展并行I/O 口,一般不用于两个MCS51之间的串行通信。该方式以 fosc/12的固定波特率从低为位到高位发送或接受数据。15 .答:直接以TTL电平申行传输数据的方式的缺点是传输距离短,抗干扰能力 差。因此在串行传输距离较远时,常采用 RS232G RS422A和RS485标准用行 接口。主要是对传输的电信号不断改进,如 RS232C传输距离只有几十米远,与 直接以TTL电平申行传输相比,采用了负逻辑,增大“ 0”

29、、“1”信号的电平差。而RS422A和RS485都采用了差分信号传输,抗干扰能力强,距离可达1000多米。RS422A为全双工,RS485为半双工。第8章AT89S51单片机扩展存储器的设计1 .答:程序、数据。2 .答:80H。3 .答:片选。4,答:16KR5 .答:程序、数据。6 .答:2K, 14。7 .答:0FFFH8 .答:(D)9 .答:本题主要考察对外部存储器的读、写操作,只要记住正确使用MOVX指令就可以了。编程思路:首先读取2001H的值,保存在寄存器A中,将寄存器A 的高四位和低四位互换,再屏蔽掉低四位然后将寄存器A的值保存到30H中,然后再读取2002H的值,保存在寄存

30、器A中,屏蔽掉高四位,然后将寄存器 A 的值与30H进行或运算,将运算后的结果保存在 2002H中。ORG 0000HDPTR #2001H;设置数据指针的初值 MAIN : MOVMOVX A, DPTR ;读取 2001H 的值 SWAP AANL A, #0F0H;屏蔽掉低四位;保存 MOV A 30H , A;指针指向下一个INC DPTRDPTR , A MOVX 的值 2002H;读取ANL A, #0FH ;屏蔽掉高四位;进行拼装A , 30HORL;保存到 2002H MOVX DPTR A END10 .答:本题主要考察对外部数据块的写操作;编程时只要注意循环次数和 MOVX

31、 指令的使用就可以了。ORG 0000HA, #0MOV;送预置数给 A MAIN:MOV R0 , #0FFH ;设置循环次数DPTR #4000H;设置数据指针的初值 MOVLOOP : MOVX DPTR A ;当前单元清零;指向下一个单元DPTRINC;是否结束 R0, DJNZ LOOP END11 .答:因为控制信号线的不同:外扩的RAM芯片既能读出又能写入,所以通常都有读写控制引脚,记为OE%WE*。外扩RAM的读、写控制引脚分别与 AT89S51的RD*和WR*引脚相连。 外扩的EPROM在正常使用中只能读出,不能写入,故 EPROM芯片没有写入控 制引脚,只有读出弓唧,记为

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

33、错,在81C55芯片中,弓I脚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)中断传送方式:中断传送方式是利用 AT89S5体身的中断功能和I/O接 口的中断功能来实现I./O数据的传送。单片机只有在外设准备好后,发出数据传 送请求,才中断主程序,而进入与外设进行数据传送的中断服务程序,进行数据的传送。中断服务完成后又返回主程序继续执行。因此,中断方式可大大提高工作效率。4 .答:两种。(1)独立编址方式:独立编址方式就是I/O地址空间和存储器地址 空间分开编址。独立编址的优点是I/O地址空间和存储器地址空间相互独立,界 限分明。但却需要

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

36、0100HDPTR,#7FFFH 控制字寄存器地址 7FFFH送 DPTR MAIN: MOVMOV ;将 PC7置 0 A,#0EHMOVX DPTR,AMOV A,#09H;将 PC4 置 1MOVX DPTR,AEND7 .答:当外设输入一个数据并送到 PA7 PA0上时,输入设备自动在选通输入线 a向82C55发送一个低电平选通信号,则把PA7-PA0上输入的数据存入PA 口的输 入数据缓冲/锁存器;然后使输入缓冲器输出线 旧F变成高电平,以通知输入设 备,82C55的PA 口已收a到它送来的输入数据。82C55检测到联络线 旧F为由低电平变成了高电平、1状 态和中aa断允许触发器IN

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

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

39、 DPTR #0FF7DH ; PB 口 地址送 DPTR;读入开关信息MOVX A, DPTRMOV DPTR , #0FF7CH ; PA 口地址送 DPTR;PA口的内容送PB 口点亮相应的二极管 MOVX DPTR AEND10.答:81C55计数器的初值范围是:3FFFH2H。当频率为4MHz,初值为3FFFH 时,最大定时时间为:0.004096S111MHz10ms的方波,实际上就是分频。分频前后频率之比为的脉冲改变为.答: 将100:164HI/O7F00H7F05H ),这样只要将定时器初值设置为(假设就可以了。口地址为START MOV DPTR #7F04H ;指针指向计

40、数器低 8位A, #64H;送初值给A MOV MOVX DPTR A ;初值送给计数器低8位;指向计数器高8位 DPTR INC;计数器方波输出 A MOV, #40HMOVX DPTE ADPTR #7F00H;指向命令MOV /状态口A, #0C2H;设定控制字MOV;启动计数器 MOVX DPTE , A END第10章AT89S51与键盘、显示器、拨盘、打印机的接口设计1 .答:A. MAX721配专用显示器芯片,不用于键盘; B.错:CH451芯片也可 用于控制键盘;C.对:BUSY信号可作为查询信号或中断请求信号使用,但此 时信号不用;E,错: ACK LED数码管的字型码是可以

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

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

43、,将两次读到的值组合在一起就得到了按键的特 征码,在根据特征码查找键值。KEYIN: MOV P1,#0FH;反转读键A,P1 MOVA,#0FH ANLB,A MOVP1,#0F0H MOVA,P1 MOVA,#0F0H ANLA,BORLA,#0FFH,KEYIN1 CJNERET;未按键B,A MOV KEYIN1:;暂存特征码MOV DPTR,#KEYCOD ;指向特征码表;顺序码初始化 R3,#0FFH MOV KEYIN2: INC R3A,R3 MOVMOVC A,A+DPTRCJNE A,B,KEYIN3MOV ;找到,取顺序码 A,R3RETKEYIN3: CJNE A,#0

44、FFH, KEYIN2 ;未完,再查;已查完,未找到,以未按键处理 RETKEYCOD: DB 0E7H,0EBH,0EDH,0EEH 特征码表 0D7H,0DBH,0DDH,0DEH DB 0B7H,0BBH,0BDH,0BEH DB77H,7BH,7DH,7EHDB7 .答:(1)编程扫描方式:当单片机空闲时,才调用键盘扫描子程序,反复的 扫描键盘,等待用户从键盘上输入命令或数据,来响应键盘的输入请求。(2)定时扫描工作方式:单片机对键盘的扫描也可用定时扫描方式, 即每隔一定的时间 对键盘扫描一次。(3)中断工作方式:只有在键盘有键按下时,才执行键盘扫描 程序并执行该按键功能程序,如果无键

45、按下,单片机将不理睬键盘。8 .答:DB0-DB7数据线,单向传输,由单片机输入给打印机。STB (STROBE数据选通信号。在该信号的上升沿,数据线上的8位并行数据被打印机读入机内 锁存。BUSY打印机忙状态信号。当该信号有效(高电平)时,表示打印机正忙 于处理数据。此时,单片机不得使STBIF号有效,向打印机送入新的数据。ACK 打印机的应答信号。低电平有效,表明打印机已取走数据线上的数据。ERR出错信号。当送入打印机的命令格式出错时,打印机立即打印1行出错信息,提示出错。在打印出错信息之前。该信号线出现一 个负脉冲,脉冲宽度为30uso单片机与打印机相连时,分为直接相连(图10-27)和

46、通过扩展的并行I/O 口 82C55 连接(图10-28)。直接相连时(图10-27),打印机在输入电路中有锁存器,在 输出电路中有三态门控制,。没有读、写信号,只有握手线、BUSY或),用一根 地址线来控制 ACKSTB写选通信号STBft读取BUS¥I脚状态。图10-28所示为通过扩展的并行I/O 口 82C55连接的打印机接口电路。采用查询法,即通 过读与82C55的PC0脚的相连的BUSY犬态,来判断 INT0引直接与单片机 的送给打印机的一个字节的数据是否处理完毕。也可用中断法(BUSY却相连)。9 .答:本程序采用外部中断来进行数据打印,先打印一个数据,当BUSYI从高电

47、平变成低电平时,在打印下一个数据ORG 0000HMAIN LJMP0003H ORGIN LJMP0030H ORGEX0 SETB ;允许外部中断 MAIN:SETB IT0SETB EAMOV ;控制口地址R0,#7FHMOV A,#81H;控制字MOVX R0,AMOV R1,#20H;数据区首地址 ;计数器R2,#19MOVMOV A,R1;打印内容口地址 A MOV ; R0,#7CHR0,A MOVXR0,#7FH MOVA,#0EH MOV 0二;RO,A MOVX PC7 A,#0FH MOVMOVX ; PC7=1R0,ASJMP $个数据都结束了吗? ; DJNZ IN:

48、 R2,EX 20;指向下一个数据INC R1A,R1 MOVR0,#7CH MOVMOVX R0,AMOV R0,#7FHMOV A,#0EHRO,A MOVXMOV A,#0FHR0,AMOVXEX: RETI第11章AT89S51单片机与D/A转换器、A/D转换器的接口1 .答:由运算放大器构成的I/V转换电路2 .答:同步3 .答:(1)错,D/A转换器也要考虑“转换速度”或“转换时间”问题,即建 立时间(转换时间);(2)对;(3)错,是D/A转换器的分辨率;(4)对。4 .答:D/A转换器的主要技术指标如下:分辨率:D/A转换器的分辨率指输入的单位数字量变化引起的模拟量输出的变 化

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

50、上用输出二进制位数或 BCD码位数表示。6 .答:量化误差是由于有限位数字且对模拟量进行量化而引起的;最大的量化 误差为0.195%7 .答:目前应用较广泛的主要有以下几种类型:逐次逼近式转换器、双积分式转换器、三-式A/D转换器。逐次逼近型A/D转换器:在精度、速度和价格 上都适中,是最常用的A/D转换器件。双积分A/D转换器:具有精度高、抗 干扰性好、价格低廉等优点,但转换速度慢,近年来在单片机应用领域中也得到 广泛应用。E -式A/ D转换器:具有积分式与逐次逼近式ADC的双重优点,它对工业现场的用模干扰具有较强的抑制 能力,不亚于双积分ADC,它比双积分ADC有较高的转换速度。与逐次逼

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

52、 #00H R3MOV , #50 R8 MOV, #08H DPTR #7FF8H MLOOP OV LOOP1 MOVX DPTR A MOV #0AH, R6 NOP DELAY NOPNOP , DELAYR6DJNZMOVX , ADPTRINC DPTRR2, DPLMOVDPH, R0MOVDPL R1MOVMOVX DPTR AINC DPTRR0, DPH MOVR1MOV , DPLDPH, #7FH MOVDPL R2MOVR7DJNZ, LOOP1LCALL DELAY1M ;延时1分钟(子程序另外编写)DJNZ R3 LOOP第12章单片机的串行扩展技术222CIC总

53、线系统直接与具有总线系统的基本结构如图12-7。I1.答:系统连接简单:IC总线接口的各种扩展器件(如存储器、I/O芯片、A/D、D/A、键盘、显示 器、日历/时钟)2c总线对各器件寻址采用纯软件的寻址方法,无需片选线的连 接,这样就大大简化I连接。了总线数量,系统各部件之间的连接只需两条线。2c普通模式下,数据的传输速率为100kbit/s,高速模式下数据传输速率较高: 在标准I可达400kbit/s。2CI.答:2总线的起始信号和终止信号都由主机发出,在起始信号产生后,总线就处于占用状态;在终止信号产生后,总线就处于空闲状态。由图12-9见起始信号和终止信号的规定。(1)起始信号(S)。在

54、SC段为高电平期间,SDA线由高电平向低电平的变化 表示起始信号,只有在起始信号以后,其他命令才有效。(2)终止信号(P)。在SC域为高电平期间,SDA线由低电平向高电平的变化 表示终止信号。随着终止信号的出现,所有外部操作都结束。2c总线上的数据传输方向由寻址字节中的数据传输方向位规定:I 3.答:无论器件地址 弓I脚地址 方向位 寻址字节 A1 A0DA2 DA1 DA0 A2 DA3 r/wWW=0,表示主机发送(写)。,表示主机接收(读)。R/R/ =12CI总线中的器件寻 址采用软件寻址,主机在发送完起始信号后,立 4.答:单片机对即发送寻址字 节来寻址被控的从机,寻址字节格式如题3

55、所示。7位从机地址即为“DA& DA2、 DA1、DA0” 和 “A2、A1、A0”。其中 “ DA3、DA2、DA1、DA0'为器件地址,是 外围器件固有的地址编码,器件出厂时就已经给定。“A2、A1、A0”为引脚地址, 由器件引脚A2、A1、A0在电路中接高电平或接地决定(见图12-12)。2c总线数据传送时,传送的字节数(数据帧)没有限制,每一字节必须为85.答: I位长。数据传送时,先传送最高位,每一个被传字节后面都须跟1位应答位(一 帧数据共92C总线在传送每一字节数据后都须有应答信号 A, A信号在第9个时 钟10位),如图12-。I位上出现,A信号对应的时钟由主机

56、产生。这时发方须在 该时钟位上使SDA线处于高电平,以便收方在这一位上送出低电平的应答信号 Ac 由于某原因收方不对主机寻址信号应答时,例如接收方正在进行其他处理而无法 接收总线上的数据时,必须释放总线,将数据线置为高电平,而由主机产生一个 终止信号以结束总线的数据传送。当主机接收来自从机的数据时,接收到最后一个数据字节后,必须给从机发送一 个非一应答信号(),使从机释放数据总线,以便主机发送一个终止信号,从而 结束数据的传送。A6.答:依照下面的数据传送格式:S 0 A Sr 1 A P数据数据 从机地址 从机地址r A/ AA依次调用依照上述数据传送格式 的12.5.2小节中的各子程序。第13章AT89S51单片机的应用设计与调试1 .答:A.错;B.错;C. Xt; D.错(最小系统不能直接测量模拟信号)。2 .答:用户样机是以AT89S51单片机为核心的应用系统,没有对单片机中的程 序进行检错调试的手段,也无法发现程

温馨提示

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

评论

0/150

提交评论