• 223.50 KB
  • 2022-04-29 14:05:47 发布

单片机原理及应用课后习题参考答案1~6章.doc

  • 21页
  • 当前文档由用户上传发布,收益归属用户
  1. 1、本文档共5页,可阅读全部内容。
  2. 2、本文档内容版权归属内容提供方,所产生的收益全部归内容提供方所有。如果您对本文有版权争议,可选择认领,认领后既往收益都归您。
  3. 3、本文档由用户上传,本站不保证质量和数量令人满意,可能有诸多瑕疵,付费之前,请仔细先通过免费阅读内容等途径辨别内容交易风险。如存在严重挂羊头卖狗肉之情形,可联系本站下载客服投诉处理。
  4. 文档侵权举报电话:19940600175。
'《单片机原理及应用》习题答案第一章计算机基础知识1-1微型计算机主要由哪几部分组成?各部分有何功能?答:一台微型计算机由中央处理单元(CPU)、存储器、I/O接口及I/O设备等组成,相互之间通过三组总线(Bus):即地址总线AB、数据总线DB和控制总线CB来连接。CPU由运算器和控制器组成,运算器能够完成各种算术运算和逻辑运算操作,控制器用于控制计算机进行各种操作。存储器是计算机系统中的“记忆”装置,其功能是存放程序和数据。按其功能可分为RAM和ROM。输入/输出(I/O)接口是CPU与外部设备进行信息交换的部件。总线是将CPU、存储器和I/O接口等相对独立的功能部件连接起来,并传送信息的公共通道。1-3什么叫单片机?其主要由哪几部分组成?答:单片机(SingleChipMicrocomputer)是指把CPU、RAM、ROM、定时器/计数器以及I/O接口电路等主要部件集成在一块半导体芯片上的微型计算机。1-4在各种系列的单片机中,片内ROM的配置有几种形式?用户应根据什么原则来选用?答:单片机片内ROM的配置状态可分四种:(1)片内掩膜(Mask)ROM型单片机(如8051),适合于定型大批量应用产品的生产;(2)片内EPROM型单片机(如8751),适合于研制产品样机;(3)片内无ROM型单片机(如8031),需外接EPROM,单片机扩展灵活,适用于研制新产品;(4)EEPROM(或FlashROM)型单片机(如89C51),内部程序存储器电可擦除,使用更方便。1-5写出下列各数的另两种数制的表达形式(二、十、十六进制)1100010100111001000111100100100111111101101100111011011101011198200395851623629149562H4E47H249H3F6CH1D5D71-6写出下列各数的BCD参与:59:01011001,1996:0001100110010110,4859.2:0100100001011001.0010389.41:001110001001.01000001 第二章MCS-51单片机的硬件结构2-18052单片机片内包含哪些主要逻辑功能部件?答:8052单片机片内包括:①8位中央处理器CPU一个②片内振荡器及时钟电路③256B数据存储器RAM。④8KB片内程序存储空间ROM⑤21个特殊功能寄存器SFR⑥4个8位并行I/O端口(32条线)⑦1个可编程全双工串行口⑧可寻址64KB的外部程序存储空间和外部数据存储空间⑨3个16位的定时器/计数器⑩6个中断源、2个优先级嵌套中断结构2-28052的存储器分哪几个空间?如何区别不同空间的寻址?答:⑴8052的存储器分为6个编址空间:①片内ROM的容量为8KB,其地址为0000H~1FFFH;②可扩展片外ROM的容量为64KB,其地址为0000H~FFFFH;片内RAM的容量为256B,其地址为00H~FFH分为二块:③地址00H~7FH共128B为片内RAM低区,④另128B为片内RAM高区,其地址空间为80H`FFH,其地址空间与SFR功能寄存器地址重叠;⑤可扩展片外RAM的容量为64KB,其地址为0000H~1FFFH;⑥特殊功能寄存器SFR的空间为128B,其地址为80H~FFH,但实际只定义了26B单元,这26B单元分散在80H`F0H。⑵程序存储器和数据存储器在逻辑上是完全分开的。CPU通过指令MOVC访问程序存储器。当8052第31脚接高电平时,CPU将从片内程序存储器0000H单元开始执行,当PC值超出片内程序存储空间,即大于1FFFH时,会自动转向片外程序存储空间。当接低电平时,CPU将从片外程序存储器ROM的0000H单元开始执行。CPU通过MOV指令访问片内数据存储空间RAM,低区128B地址空间00H~7FH中地址为00H~1FH这32个单元分为4个工作寄存器组,分别用R0~R7表示,通过工作寄存器指令进行访问。片内RAM中的20H~2FH单元除可作为一般字节寻址单元使用外,这16个单元共128位中的每一位又可单独作为软件触发器使用,具有位寻址功能,其位地址范围为00H`7FH;对片内高区128B寻址只能用寄存器间接寻址,而对特殊功能寄存器建起必须使用直接寻址。 CPU通过指令MOVX访问片外数据存储器。2-3DPTR的作用是什么?它由哪几个寄存器组成?答:相对于地址指针,DPTR被称为数据指针,但实际上DPTR中存放的是一个16位的地址,作为访问程序存储器和外部数据存储器的地址指针。当对64KB外部数据存储器空间寻址时,作为间址寄存器使用,而在访问程序存储器时,作为基址寄存器使用。DPTR是一个16位的特殊功能寄存器,由两个8位寄存器DPH、DPL组成,使用SFR中的82H和83H单元。2-4简述布尔处理存储器的空间分配。答:在单片机中位处理又称布尔处理,允许按位处理的存储器称为布尔处理存储器。其地址空间由二部分构成:一部分是片内RAM中字节地址为20H~2FH的16字节的128个位,这些位编址为00H`7FH;另一部分在特殊寄存器中,其地址码能被8整除的12个特殊功能寄存器可以按位寻址,但其中4个未定义,一共有92位可按位寻址。这二部分结合起来形成一个具有220位的位寻址空间。2-58052单片机设置4组工作寄存器,如何选择确定和改变当前工作寄存器?答:8052片内数据存储器的00H~1FH这32个单元分为4级作为4个工作寄存器第0组地址00H`07H,第一组08H~0FH,第二组10H~17H,第3组18H~1FH。每个工作寄存器都有8个单元,分别用R0~R7表示。4组寄存器中每一组都可能被选为CPU的工作寄存器,这是通过程序状态字PSW的PSW.3(RS0)和PSW.4(RS1)两位的状态来选择决定的。见下表:PSW.4(RS1)PSW.3(RS0)当前使用的工作寄存器组R0`R7000组(00H`07H)011组(08H`0FH)102组(10H`17H)113组(18H`1FH)通过程序改变RS1和RS0的状态,就可方便地更换工作寄存器组。2-6程序状态字寄存器PSW的作用是什么?常用的状态标志位有哪些位?作用分别是什么?答:PSW是一个8位的特殊功能寄存器,由一些标志位组成,用于存放程序运行中的各种状态信息。它可以进行位寻址。各位的作用如下:Cy:进位标志位。在进行加(或减)法运算时,若操作结果的最高位(D7位)有进位(或借位)时,Cy由硬件置1,否则Cy清0。在进行位操作时,Cy又是位累加器,指令助记符用C表示。AC :辅助进位标志位。在进行加(或减)运算时,若操作结果的低半字节(D3位)向高半字节产生进位(或借位)时,AC位将由硬件自动置1,否则AC位清0。F0:用户标志位。用户根据需要对F0置位或复位,作为软件标志。RS1和RS0:工作寄存器组选择控制位。由用户用软件改变RS1和RS0的状态,以选择内RAM中的哪组工作寄存器为当前工作寄存器组。OV:溢出标志位。当进行补码运算时,运算结果超出-128~+127范围时,产生溢出,则OV自动置1,否则OV清0。PSW.1:保留位。8051中未定义。P:奇偶校验标志位。每条指令执行完后,该位始终跟踪累加器A中1的数目的奇偶性。如果A中有奇数个1,则P=1;否则P=0。2-78052单片机的引脚有何功能?在使用8032时,引脚就如何处理?答:8052单片机的31脚为,为访问外部或内部程序存储器控制信号。当引脚接高电平且PC值小于1FFFH时,CPU访问内部程序存储器读取指令,当引脚接低电平时,CPU只访问外部等量齐观存储器读取指令。在8032芯片中没有内部程序存储器,因此,8032芯片的31脚只能接地。2-88052内部RAM中低128B单元划分为哪几个主要部分?各部分主要功能是什么?答:8052内部数据存储器RAM中低128B单元地址空间00H~7FH被划分为三个部分。第一部分地址为00H~1FH这32个单元分为4个工作寄存器组,分别用R0~R7表示,通过工作寄存器指令进行访问。片内RAM中的第二部分20H~2FH单元除可作为一般字节寻址单元使用外,这16个单元共128位中的每一位又可单独作为软件触发器使用,具有位寻址功能,其位地址范围为00H`7FH;第三部分地址30H~7FH,这部分存储区域可作为8位数据缓冲区使用,一般地,用户把堆栈就设置在这部分区域。2-98052内部RAM中高128B单元与特殊功能寄存器区地址空间重叠,使用中是如何区分这两个空间的?答:对8052片内高区(80H`0FFH)128B只能采用寄存器间接寻址,而对特殊功能寄存器SFR建起必须采用直接寻址。2-10什么叫堆栈?堆栈指针SP的作用是什么?答:堆栈是按照“先进后出,后进先出”的原则来存取数据的一个内部RAM区域,这个存储器区域的一端是固定的(栈底),另一端是活动的(栈顶),每个存储单元是不能按字节任意访问的。堆栈指针SP始终指向栈顶单元,栈顶随着数据入栈和出栈上下浮动。 2-12什么是时钟周期、机器周期和指令周期?答:(1)时钟周期(又称为振荡周期)是指振荡器产生一个振荡脉冲信号所用的时间,是振荡频率的倒数,称为拍节。(2)机器周期是指CPU完成某一个规定操作所需的时间,8051单片机的一个机器周期包含6个状态,并依次表示为S1~S6,每个状态分为2个节拍。因此一个机器周期包含12个时钟周期(振荡周期),依次表示为:S1P1、S1P2、S2P1、…、S6P1、S6P2。(3)指令周期是指CPU执行一条指令所需要的时间称为指令周期。MCS-51单片机指令周期根据指令的不同,可包含有1或2或4个机器周期。第三章MCS-51单片机指令系统3-1指出下列每一条指令的寻址方式及其完成的操作。MOV2FH,#40H;立即寻址,将40H移入片内2FH单元MOVA,2FH;直接寻址,将片内2FH单元的数移入累加器AMOVR1,#2FH;立即寻址,将2FH移入当前寄存器组的R1单元MOVA,@R1;寄存器间接寻址,将寄存器R1中所存地址中的值移入累加器AMOV2FH,A;隐含寻址,将累加器A中的值移入片内2FH单元3-2内部RAM的4FH单元,可用哪几种寻址方式?分别举例说明。答:直接寻址:MOVR1,4FH间接寻址:MOVR1,#4FH寄存器间接寻址:MOVA,@R13-3指出下列各条指令中,45H代表什么?MOVA,#45H;数值MOVA,45H;源地址MOV45H,46H;目标地址MOV45H,#45H;目标地址和数值MOVC,45H;源地址3-4已知:(A)=7AH,(R0)=30H,(30H)=0A5H,(PSW)=80H,请写出下列各条指令的执行结果:答:PSW的各位为11110000,即Cy=1,AC=1,F0=1,RS1=1,RS0=0,OV=0,P=0(1)SUBBA,30H结果:(A)=D4H,CY=1,AC=0,OV=1,P=0(2)SUBBA,#30H结果:(A)=49H,CY=0,AC=0,OV=0,P=1 (3)ADDA,R0结果:(A)=AAH,CY=0,AC=0,OV=1,P=0(4)ADDA,30H结果:(A)=1FH,CY=1,AC=0,OV=0,P=1(5)ADDA,#30H结果:(A)=AAH,CY=0,AC=0,OV=1,P=0(6)ADDCA,30H结果:(A)=20H,CY=1,AC=1,OV=0,P=1(7)SWAPA结果:(A)=A7H,对标志位无影响(8)XCHDA,@R0结果:(A)=75H,(30H)=AAH,(R0)=AAH,P=1(9)XCHA,30H结果:(A)=0A5H,(30H)=7AH,P=0(10)XCHA,R0结果:(A)=30H,(R0)=7AH,P=0(11)MOVA,@R0结果:(A)=0A5H,P=0(12)XCHA,@R0结果:(A)=0A5H,(30H)=7AH,P=03-5试分析以下程序段的执行结果:MOVSP,#3AHMOVA,#20HMOVB,#30HPUSHACCPUSHBPOPACCPOPB结果:(SP)=3AH,(A)=30H,(B)=20H,(3BH)=20H,(3CH)=30H3-6指出下列指令的执行结果,并写出每条指令的机器码。MOV30H,#52H;(30H)=52H01110101(753052H)MOVA,#70H;(A)=70H01110100(7470H)MOVA,30H;(A)=52H11100101(E530H)MOVR0,#30H;(R0)=30H10101000(7830H) MOVA,@R0;A=52H11100010(E6H)3-7分析下列指令的执行结果,并写出每条指令的机器码。MOVA,#70H;(A)=70H01110100(74H)MOVDPTR,#2030H;(DPTR)=2030H10010000(90H)MOVX@DPTR,A;(2030H)=70H11110000(F0H)MOV30H,#40H;(30H)=40H01110101(75H)MOVR0,#30H;(R0)=30H01111000(78H)MOVA,@R0;(A)=40H11100110(E6H)3-8设R0的内容为32H,A的内容为48H,内部RAM的32H单元内容为80H,40单元内容为08H,指出在执行下列程序段后上述各单元内容的变化。MOVA,@R0MOV@R0,40HMOV40H,AMOVR0,#35H结果:(R0)=35H,(A)=80,(32H)=08H,(40H)=80H3-9已知:(A)=81H,(R0)=20H,(20H)=35H,指出执行完下列程序段后A的内容。ANLA,#17H;(A)=00000001ORL20H,A;(20H)=00110101XRLA,@R0;(A)=00110100CPLA;(A)=11001011结果:(A)=CBH3-10用指令实现下述数据传送:(1)内部RAM20H单元送内部RAM40H单元。答:MOV40H,20H(2)外部RAM20H单元送R0寄存器。答:MOVR1,#20HMOVXA,@R1MOVR0,A(3)外部RAM20H单元送内部RAM20H单元答:MOVR1,#20HMOVXA,@R1MOV20H,A(4)外部RAM1000H单元送内部RAM20H单元答:MOVDPTR,#1000HMOVXA,@DPTRMOV20H,A(5)外部ROM1000H单元送内部RAM20H单元。答:MOVDPTR,#1000HMOVA,#00HMOVCA,@A+DPTRMOV20H,A(6)外部ROM1000H单元送外部RAM20H单元。 答:MOVDPTR,#1000HMOVA,#00HMOVCA,@A+DPTRMOVR1,#20HMOVX@R1,A3-11已知16位二进制数的高8位和低8位分别存放在20H和21H单元,请编写将其右移一们的程序。CLRCMOVA,20HRRCAMOV20H,AMOVA,21HRRCAMOV21H,A3-12编程实现内部RAMR0~R7的内容传递到20H~27H单元。3-13试编程进行两个16位数的减法,6F5DH-13B4H,结果存入内部RAM的30H和31H单元,30H存放差的低8位。CLRCMOVA,#5DHSUBBA,#B4HMOV30H,AMOVA,#6FHSUBBA,13HMOV31H,A3-14编写程序,若累加器A的内容分别满足下列条件时,程序则至LABEL存储单元,设A中存放的是无符号数。①A>=10②A>0③(A)<=10CJNEA,#10H,LABJNZLABELMOVR0,ALAB:JNCLABELMOVA,#10............CJNEA,R0,LABLABEL:LABEL:LAB:JNCLABEL......LABEL:3-15已知(SP)=25H,(PC)=2345H,(24H)=12H,(25H)=34H,(26H)=56H.问此时执行“RET”指令后,(SP)=?,(PC)=?答:(SP)=23H,(PC)=3412H执行RET时,PCH←(SP),SP←SP-1,PCL←(SP),SP←SP-1 3-16若(sp)=25H,(PC)=2345H,标号LABEL所在的地址为3456H,问执行调用指令“LCALLLABEL”后,堆栈指针和堆栈内容发生什么变化?(PC)的值等于什么?答:最后堆栈指针SP=27H。堆栈指针SP=26H处SP内容为45H,指针SP=27H处内容为23H。最后程序计数器指针PC=3456H。执行LCALL后,PC←PC+3,SP←SP+1,(SP)←PCL,SP←SP+1,(SP)←PCH,PC←addr16。3-17试编写程序,查找在内部RAM的20H~50H单元中是否有0AAH这一数据。若有,则将51H单元置01H,若未找到,则将51H单元置00H。MOV51H,#00H;先设没找到MOVR0,#20H;起始地址LOOP:MOVA,@R0;取出数字CJNEA,#0AAH,NEXT;不相等就跳转INC51H;相等将51单元置1SJMPEEE;找到转去结束NEXT:INCR0;下一个地址CJNER0,#51H,LOOP;地址没找完就继续EEE:SJMP$;暂停3-18试编写程序,统计在外部RAM2000H~205FH单元中出现00H的次数,并将统计结果丰收入内部RAM50H单元。MOVR0,#00H;RO设为计数器,初始为0MOVDPTR,#2000H;置片外RAM起始地址MOVR1,#60H;置传送数据个数LOOP:MOVXA,@DPTR;外部RAM单元内容送AJNZNEXT;传送数据不为0跳转INCR0;传送数据为0,计数器加1NEXT:INCDPTR;下一个地址DJNZR1,LOOP;地址没找完就继续MOV50H,R0;统计结果存入50H单元SJMP$;暂停3-19已知R3和R4中存有一个16位的二进制数,高位在R3中代位在R4中。请编程将其求补,并存回原处。答:首先假设R3、R4中是原码,根据原码求补的方法当最高位(R3的D7位)为0时表示为正数,那么补码与原码相同,当最高位为1 时,表明是负数,负数的补码是最高位不变,其余位取反加1.MOVA,R3JBACC.7,NEGSJMP$NEG:MOVA,R4CPLACLRCADDA,#01HMOVR4,AMOVA,R3CPLAADDCA,#00HSETBACC.7MOVR3,ASJMP$3-20编写一个程序,把片外RAM从2000H开始存放的10个数传送到片内RAM30H开始单元。START:MOVR0,#30HMOVR1,#10HMOVDPTR,#2000HLOOP:MOVXA,@DPTRMOV@R0,AINCR0INCDPTRDJNZR1,LOOPSJMP$3-21试编程将内部RAM的30H至4FH单元的内容分别传送到外部RAM的2040H~205FH单元。START:MOVR0,#30HMOVR1,#20HMOVDPTR,#2040HLOOP:MOVA,@R0MOVX@DPTR,AINCDPTRINCR0DJNZR1,LOOPSJMP$3-22若外部RAM的(2000H)=X,(2001H)=Y,编程实现Z=3X+2Y,结果存入内部RAM的20H单元,设Z<=255。START:MOVDPTR,#2000HMOVXA,@DPTRMOVB,#03HMULABMOVR0,AINCDPTRMOVXA,@DPTRADDA,AADDA,R0MOV20H,A3-23试对内部RAM20H单元的内容进行判断,若为正数,转向2100H若为负数,转向2200H;若为0,转向2300H。START:MOVA,20HJBACC.7,NEG;为负数JNBACC.7,POSI;为0 LJMP#2100HSJMPEEENEG:LJMP#2200HSJMPEEEPOSI:LJMP#2300HSJMPEEEEEE:SJMP$3-24已知30H、31H中存有一个16位二进制数,高位在前低位在后。试编程将它们乘2,再存回原单位中。START:MOVA,31HADDA,31HMOV31H,AMOVA,30HADDCA,30HMOV30H,ASJMP$3-25已知从外部RAM2000H开始的单元中有20个带符号的补码数,试编程把正数和0取出来存放到内部RAM20H开始的存储单元中(负数为作处理)。START:MOVR0,#20H;需处理的数的个数MOVDPTR,#2000H;需处理数的起始地址MOVR1,#20H;用于存储的目标地址LOOP:MOVXA,@DPTRJBACC.7,NEG;负数不需处理MOV@R1,AINCR1NEG:INCDPTRDJNZR0,LOOPSJMP$第四章汇编语言程序设计4-1什么叫伪指令?伪指令与指令有什么区别?答:伪指令不属于单片机指令集中的指令,在汇编时不产生目标代码,不影响程序的执行,仅指明在汇编时执行一些特定的操作。如为程序指定一个存储区、将一些数据、表格常数存放在指定的存储单元、对地址赋用户名等。指令是计算机所能执行的一种基本操作的描述,是计算机软件的基本单元。51单片机单片机的指令有二种表达方式:机器码指令和汇编语言指令。4-2循环程序由哪几部分组成? 答:由初始化部分、循环处理部分、循环控制部分、循环结束部分这四部分组成。4-3什么是子程序?对于子程序设计有什么要求?答:一段具有某一特定功能,能被其它程序所调用,调用结束后能自动返回到调用处的程序块就称为子程序。对子程序设计的要求:4-4试对下列程序进行人工汇编,并说明此程序的功能。地址指令码ORG1000H;ACDL:MOVR0,#25H;1000H7825MOVR1,#2BH;1002H792bMOVR2,#06H;1004H7A06CLRC;1006HC3CLRA;1007HE4LOOP:MOVA,@R0;1008HE6ADDCA,@R1;1009H37DECR0;100AH18DECR1;100BH19DJNZR2,LOOP;100CHDAFASJMP$;100EH80FEEND;1008H-100EH=-06H,其补码为(11111010)2→0FAH功能:将25H单及前5个数与2BH单元及前5个数分6组相加,结果丢弃。4-5从内部RAM的20H单元开始,有15个数据。试编一程序,把其中的正数、负数分别送到41H和61H开始的存储单元,并分别将正数、负数的个数送40H单元和60H单元。MOVR0,#41H;存放正数的起始地址MOVR1,#61H;存放负数的起始地址MOVSP,#2EH;指明栈顶地址MOVR3,#00H;正数个数MOVR4,#00H;负数个数MOVR7,#15;需判断数的个数LOOP:POPACC;出栈放入AJBACC.7,NEG;负数跳转 CJNEA,#00H,LOOP1;非负非零转正数处理SJMPLOOP;零不处理,取下一个数LOOP1:MOV@R0,A;正数保存INCR0;正数存放地址加1INCR3;正数个数加1SJMPLOOP2;未结束就继续NEG:MOV@R1,A;将负数送负数保存地址INCR1;负数地址加1INCR4;负数个数加1LOOP2:DJNZR7,LOOP;未结束就继续MOV40H,R3;正数个数送40H单元MOV60H,R4;负数个数送60H单元SJMP$END4-6设内部RAM的30H和31H单元中有二个带符号数求出其中的大数存放在32H单元中。MOVA,30HXRLA,31HJBACC.7,LOOPMOVA,30HSUBBA,31HJCLOOP1MOV32H,30HSJMP$LOOP1:MOV32H,31HSJMP$LOOP:MOVA,30HJBACC.7,LOOP1MOV32H,ASJMP$4-7试编制实现ASCII码转十进制数的程序。在8032单片机内RAM的40H单元中存放一个代码。若此代码为十进制数的ASCII码,则将其相应的十进制数送片内RAM的50H单元,否则将此单元置成0FFH。MOVA,40HCLRCSUBBA,#30H;数字比其ASCII码值小30HJCLOOP;存的ASCII值小于0的ASCII码值跳转MOVR0,AMOVA,#09H;减30H后差大于0,是否不SUBBA,R0;大于9?JCLOOP;差大于9,跳转 MOV50H,R0;将数字存入50H单元SJMP$LOOP:MOV50H,#0FFH;不是数字,存入0FFHSJMP$END4-8试编程将存放在8032单片机内部RAM中首址为20H、长度为50H的数据快传送到片外RAM以20H为首址的连续单元中。MOVR0,#20HMOVR1,#20HMOVR7,#50HLOOP:MOVA,@R0MOVX@R1,AINCR0INCR1DJNZR7,LOOPSJMP$4-9设一个字符串存放在8032单片机内部RAM以20H为首址的连续单元中,字符串以回车结束。要求统计该字符串中字符C(’C’=43H)的个数,并将其存入外部RAM的40H单元。试编写实现上述要求的程序。MOVR0,#20HMOVR2,#00HLOOP:MOVA,@R0XRLA,#0DH;判断是否是回车符JZEXITMOVA,@R0XRLA,#43HJNZLOOP2INCR2LOOP2:INCR0SJMPLOOPEXIT:MOVDPTR,#0040HMOVA,R2MOVX@DPTR,ASJMP$END4-10设有一长度为20H的字符串,它存放在片外RAM1000H为首地址的连续单元中。试编制将其中数字与字母分开并将它们送到片内RAM以30H和50H为首地址的连续单元中的程序。MOVDPTR,#1000HMOVR7,#20HMOVR0,#30HMOVR1,#50HLOOP:MOVXA,@DPTRCJNEA,#30H,LOOP1SJMPISNUMLOOP1:JNCLOOP2SJMPISCHARLOOP2:CJNEA,#3AH,LOOP3LOOP3:JCISNUMSJMPISCHARISCHAR:MOV@R1,AINCR1 SJMPNEXTISNUM:CLRCSUBBA,#30HMOV@R0,AINCR0SJMPNEXTNEXT:INCDPTRDJNZR7,LOOPSJMP$END4-11试编程将片内RAM区DATA1单元开始的20H个单字节依次与DATA2单元为起始地址的20H个单字节进行交换。MAIN:MOVR7,#20HDATA1EQU20HDATA2EQU40HMOVR0,#DATA1MOVR1,#DATA2LOOP:MOVA,@R0XCHA,@R1MOV@R0,AINCR0INCR1DJNZR7,LOOPSJMP$END4-13设片内RAM的20H~4FH单元中有若个无符号数,试编程求出其中的最大值及所在单元地址,将最大值存入片内RAM的50H单元,最大值所在单元地址存入片内RAM的51H单元。MOVR0,#20HMOVR7,#20HMOVA,R0MOVR2,AMOVA,@R0MOVR1,ALOOP:INCR0CLRCSUBBA,@R0JNCLOOP1MOVA,R0MOVR2,AMOVA,@R0MOVR1,ALOOP1:MOVA,R1DJNZR7,LOOPMOV50H,R1MOV51H,R2SJMP$END4-14设片外RAM从1000H单元开始存放100个无符号8位二进制数。试编程将它们从大到小依次入片内RAM从10H开始的单元中。MOVR7,#100MOVDPTR,#1000HMOVR0,#10HLOOP:MOVXA,@DPTRMOV@R0,AINCDPTRINCR0DJNZR7,LOOPMOVR7,#99MOVR6,#99 NEXT:MOVR0,#10HMOVA,@R0MOVR1,ALOOP2:INCR0MOVA,@R0CLRCSUBBA,R1JNZLOOP3SJMPLOOP4LOOP3:JCLOOP4MOVA,@R0DECR0MOV@R0,AMOVA,R1INCR0MOV@R0,ALOOP4:MOVA,@R0MOVR1,ADJNZR7,LOOP2DECR6MOVA,R6MOVR7,AINCR6DJNZR6,NEXTSJMP$END4-15设有2个4B的BCD数:X=24350809,Y=12450379。X从片内RAM的25H单元开始存放,Y从片内RAM的35H单元开始存放,求两数的和。设数据在内存中按照低字节在前,高字节在后的顺序存放。MOV25H,#24HMOV26H,#35HMOV27H,#08HMOV28H,#09HMOV35H,#12HMOV36H,#45HMOV37H,#03HMOV38H,#79HMOVR7,#04HMOVR0,#25HMOVR1,#35HCLRCLOOP:MOVA,@R0ADDCA,@R1DAAMOV@R0,AINCR0INCR1DJNZR7,LOOPSJMP$END4-16设晶振频率为6MHz,试编一能延时20ms的子程序答:一个机器周期T=12/6*106=2μs,延时20ms需要20000/2=10000个机器周期。拟用以下程序:工作需要机器周期数START:MOVR6,#data1;1LOOP1:MOVR7,#data2;1NOP;1 NOP;1LOOP:NOP;1NOP;1NOP;1DJNZR7,LOOP;2DJNZR6,LOOP;2RET;2延时周期数为1+(5*data2+5)*data1+2,选择最合适的data1和data2Data1=200,data2=99,延时机器周期数为10003个,延时20.006ms4-17利用查表技术将累加器A中的一位BCD码转换成相应的十进制数的七段码,结果仍放在A中(设显示管0~9的七段码分别是40H,79H,24H,30H,19H,12H,02H,78H,00H,1BH)。SUB1:INCAMOVCA,@A+PCRETDB40H,79H,24H,30H,19H,12H,02H,78H,00H,1BH4-18试编一采用查表法求1~20的二次方数的子程序。要求:X在累加器A中,1≤X≤20,二次方高位存放在R6中,低位存放在R7中。SUB:MOVDPTR,#0100HMOVR0,AADDA,R0MOVR0,AMOVCA,@A+DPTRMOVR7,AINCDPTRMOVA,R0MOVCA,@A+DPTRMOVR6,ARETORG102HDB01H,00H,04H,00H,09H,00H,10H,00H,19H,00HDB24H,00H,31H,00H,40H,00H,51H,00H,64H,00HDB79H,00H,90H,00H,0A9H,00H,0C4H,00H,0E1H,00HDB00H,01H,21H,01H,44H,01H,69H,01H,90H,01H 第五章MCS-51单片机中断系统5-1MCS-51单片机的中断系统由哪些功能部件组成?分别有什么作用?答:51单片机的中断系统由与中断有关的特殊功能寄存器(中断允许控制寄存器IE、中断优先等控制寄存器IP、定时器/计数器控制寄存器TCON、T2CON、串行口控制寄存器SCON)和6个中断源(2个外部中断源[P3.2]、[P3.3],3个定时器/计数器中断源T0[P3.4]、T1[P3.5]、T2[P1.0]),1个串行接口中断源(RXD[p3.0]接收数据中断、TXDp[P3.1]发送数据中断)组成。中断允许控制寄存器IE由七个控制位构成,其中D7位EA是所有中断的总开关,若EA=1,CPU中断允许,EA=0时,CPU屏蔽一切中断请求。其余6位D5~D0分别控制6个中断源,置1为允许申请中断,清0为禁止申请中断。其字节地址是A8H,位地址是A8H~ADH和AFH,每位都可由软件来置1或清0。中断优先等控制寄存器IP用于设置每个中断的优先级,该寄存器由6个控制位构成(D5~D1)分别控制每个中断源的优先级,置1为高优先级,置0为低优先级。其位地址为B8H~BDH,每位都可由软件来置1或清0。定时器/计数器控制寄存器TCON字节地址88H,其位地址88H~8FH,除D6和D4位用于控制定时器/计数器0、1启停外,其余6位分二组分别控制定时器/计数器0、1的中断信号方式(IT0/IT1),外部中断请求标志位(IE0/IE1)、溢出标志位(TF0/TF1)、T2CON字节地址为C8H,可按位寻址,但只有2位(D7和D6位)用作中断控制,当T2EX(P1.1脚)的负跳变有效时T2的硬件置D6位EXF2(T2CON.6)=1,tmCPU申请中断。当T2计数溢出时由硬件置D7(TF2,T2CON.7)=1,向CPU申请中断。串行口控制寄存器SCON字节地址为98H,其位地址98H~9FH。与中断有关的只有D0位和D1位。串行口发送了一帧信息,便由硬件置TI=1,向CPU申请中断。串行口接收一邓一帧信息,便由硬件置RI=1,向CPU申请中断。5-2MCS-51系列单片机能提供几个中断源?答:MCS-51系列单片机能提供6个中断源,。5-3MCS-51单片机的中断系统中有几个优先级?如何设定?MCS-51单片机有2个中断优先级。各个中断源的优先级是由特殊功能寄存器IP来确定,IP中和各个中断源对应位为1时,此中断源为高优先级,否则为低优先级。在同一优先级中,各个中断源的优先顺序是由自然优先级来确定的。5-4CPU响应中断有哪条件?在什么情况下中断响应会受阻?答:CPU响应中断的基本条件有以下三个:①有中断源提出中断请求。②中断总允许位EA=1,即CPU开放中断。③申请中断的中断源的中断允许位(ET2、ES、ET1、EX1、ET0、EX0)为1,即没有被屏蔽。在中断源提出中断申请后,有二种情况可以使中断受阻:①中断允许寄存器IE中对应于有中断请求的控制位为0,屏蔽了中断请求,即CPU没无法收到中断请求。②中断允许寄存器IE的D7位(EA位)为0,即CPU没有开放中断响应。CPU正在处理同等级或高等级中断时,CPU将在处理完该中断并返回执行一条指令后才响应新中断请求。现行的机器周期不是所执行指令的最后一个机器周期。正在执行的指令是RETI或访问IE、IP指令。5-5简述MCS-51系列单片机的中断响应过程。 答:MCS-51系列单片机的中断响应过程是按照以下顺序执行的:开中断→中断请求→中断判断→中断响应→中断返回。5-6MCS-51单片机中断响应时间是否固定?为什么?答:MCS-51单片机中断响应时间不固定,因为当中断源向CPU提出中断请求时,CPU正在执行的指令的指令周期是不一样的,一般情况下中断响应时间在3~8个机器周期之间。当然如果中断到来时是在处理同级或高级中断服务程序中,则响应时间就无法估计了。5-7MCS-51中若要扩充8个中断源,可采用哪些方法?如何确定优先级?答:一般可采取中断加查询方式,软件先查询到的为高优先级,最后查询到的为低优先级。5-88031芯片的INT0、INT1引脚分别输入压力超限、温度超限中断请求信号,定时器/计数器0作定时检测的实时时钟,用户规定的中断优先权排队次序为:压力超限→温度超限→定时检测。要求确定IE、IP的内容,以实现上述要求。答:IE设87H,IP设05H。第六章MCS-51单片机定时器/计数器6-1MCS-51单片机内部设有几个定时器/计数器?它们是由哪些专用寄存器组成的?设有3个定时器/计数器T0、T1、T2。 它们由特殊功能寄存器工作方式寄存器TMOD(字节地址89H,不能按位寻址,用来控制T0和T1的工作方式),TCON控制寄存器(字节地址88H,位地址88H~8FH,用高4位控制定时器/计数器0、1的启、停,和作溢出标志位),定时器/计数器2的控制寄存器T2CON(其字节址C8H,位地址C8H~CFH)组成,各定时器/计数器还有1个16位工作寄存器(TL0[8AH]、TH0[8CH]、TL1[8BH]、TH1[8DH]、TL2[CCH]、TH2[CDH],T2还有二字节特殊功能寄存器RLDL[CAH]和RLDH[CBH])。6-2MCS-51单片机的定时器/计数器有哪几种工作方式?各有什么特点?答:MCS-51定时器/计数器有0,1,2,3四种工作模式。模式0为13位1定时器/计数器,模式1为16位1定时器/计数器,模式2为自动赋初值的8位定时器/计数器,模式3可以增加一个8位定时器(T1没有模式3)。6-3MCS-51定时器作定时和计数时其计数脉冲分别由谁提供?答:MCS-51定时器作定时器时,输入的记数脉冲是由晶体振荡器的输出经12分频后得到的,所以定时器可看作是对单片机机器周期的计数器。8051定时器作计数器时,则对外部事件进行计数。6-48051定时器的门控信号GATE设置为1时,定时器如何启动?答:8051定时器的门控信号GATE为1时,通常先设置TR0或TR1为1,将T0或T1的启动控制权交由或。当(或)引脚为高电平时,相应的T0或T1才能选通工作。6-5定时器/计数器用作定时时,其定时时间与哪些因素有关?作计数器时,对外界计数脉冲频率有何限制?答:作定时器时,其定时时间与晶振频率、定时计数器位数、定时初值有关。作计数器时,要求外界脉冲频率小于晶振频率除24。6-6当T0设为工作方式3时,由于TR1位已被TH0占用,如何控制定时器T1的启动和关闭?答:先设置T1的初始值和工作方式0~2,由于将T1设置为工作方式3时T1会停止工作,因此可以利用M1和M2来控制T1的启动和关闭。通常在T0工作在方式3的时候,将T1设置为方式2,8位自动装初值工作方式。6-7已知8051单片机的fosc=6MHz,请利用T0和P1.2输出长形波。其长形高电平宽50us,低电平宽300us。解:(1)定时时间设为50us,低电平时间相当于持续6个定时周期。可选择于方式2,8位自动重装初值方式。X=256-6×50/12=231,即E7H(2)设置TMOD参数:T1的四位全“0”,低四位为“0010”,TMOD=02H(3)中断IE:EA=1,ET0=1.其余为0,IE=82H(4)TCON用于控制启停的TR0位在程序中用位设置。(5)编写源程序如下:ORG0000HAJMPMAINORG000BHAJMPT0INTORG0030HMAIN:MOVTH0,#0E7HMOVTL0,#0E7HMOVR7,#06HMOVTMOD,#02HMOVIE,#82HSETBTR0SETBP1.2SETBF0SJMP$ T0INT:JBCF0,LOOPDJNZR7,LOOP2SETBP1.2SETBF0MOVR7,#06HSJMPLOOP2LOOP:CLRP1.2LOOP2:RETIEND6-8已知8051单片机的fosc=12MHz,用T1定时,试编程由P1.2和P1.3分别输出周期为2ms和500us的方波解:2ms和500us的方波,以最小值500us为基本单位,将计时长度设为250us,可使用8位加法计数器,即T1的工作方式为方式2。2ms方波为4个计数溢出长度翻转一次。采用中断方式处理溢出。(1)定时初值确定:X=256-12×106×250×10-6/12=256-250=6(2)确定TMOD的参数:T0设为方式0定时器。TMOD=00100000=20H(3)编写源程序:ORG0000HAJMPMAINORG001BHAJMPT1INTORG0030HMAIN:MOVR7,#04MOVTH1,#06MOVTL1,#06MOVTMOD,#20HSETBET1SETBEASETBTR1SJMP$T1INT:CPLP1.3DJNZR7,LOOPCPLP1.2MOVR7,#04LOOP:RETIEND'