版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、练习练习练习第二章 单片机结构及原理1、MCS-51单片机内部包含哪些主要功能部件它们的作用是什么答:(1)一个8bit CPU是微处理器的核心,是运算和逻辑计算的中心。(2)片内震荡器及时钟电路:提供标准时钟信号,所有动作都依据此进行。(3)4K ROM程序存贮器:存贮程序及常用表格。(4)128B RAM 数据存贮器:存贮一些中间变量和常数等。(5)两个16bit定时器/计数器:完全硬件定时器(6)32根可编程I/O口线:标准8位双向(4个)I/O接口,每一条I/O线都能独立地作输入或输出。(7)一个可编程全双工串行口。 (8)五个中断源。2、什么是指令什么是程序答:指令是规定计算机执行某
2、种操作的命令。程序是根据任务要求有序编排指令的集合。3、如何认识89S51/52存储器空间在物理结构上可以划分为4个空间,而在逻辑上又可以划分为3个空间答:89S51/52存储器空间在物理结构上设有个存储器空间:片内程序存储器、片外程序存储器、片内数据存储器、片外数据存储器。在逻辑上有个存储器地址空间:片内、片外统一的64KB程序存储器地址空间,片内256数据存储器地址空间,片外64的数据存储器地址空间。4、开机复位后,CPU使用的是哪组工作寄存器他们的地址是多少CPU如何确定和改变当前工作寄存器组答:开机复位后,CPU使用的是第0组工作寄存器,地址为00H07H,CPU通过改变状态字寄存器P
3、SW中的RS0和RS1来确定工作寄存器组。5、什么是堆栈堆栈有何作用在程序设计时,有时为什么要对堆栈指针SP重新赋值如果CPU在操作中要使用两组工作寄存器,SP应该多大答:堆栈是一个特殊的存储区,主要功能是暂时存放数据和地址,通常用来保护断点和现场。堆栈指针SP复位后指向07H单元,00H1FH为工作寄存器区,20H2FH为位寻址区,这些单元有其他功能,因此在程序设计时,需要对SP重新赋值。如果CPU在操作中要使用两组工作寄存器,SP应该至少设置为0FH。6、89S51/52的时钟周期、机器周期、指令周期是如何分配的当振荡频率为8MHz时,一个单片机周期为多少微秒答:时钟周期为时钟脉冲频率的倒
4、数,他是单片机中最基本的、最小的时间单位。机器周期是指完成一个基本操作所需要的时间,一个机器周期由12个时钟周期组成。指令周期是执行一条指令所需要的时间,由若干个机器周期组成。 若fosc=8MHz,则一个机器周期=1/8×12s=s7、89S51/52扩展系统中,片外程序存储器和片外数据存储器共处同一地址空间为什么不会发生总线冲突答:访问片外程序存储器和访问数据存储器使用不同的指令用来区分同一地址空间。8、程序状态字寄存器PSW的作用是什么常用状态标志有哪些位作用是什么答:程序状态字PSW是8位寄存器,用于存放程序运行的状态信息,PSW中各位状态通常是在指令执行的过程中自动形成的,
5、但也可以由用户根据需要采用传送指令加以改变。各个标志位的意义如下:(Cy):进位标志位。(AC):辅助进位标志位,又称为半进位标志位。(F0):用户标志位。、(RS1和 RS0):寄存器组选择位。(OV):溢出标志位。(空缺位):此位未定义。(P):奇偶校验位。9、位地址7CH和字节地址7CH有何区别位地址7CH具体在内存中什么位置答:字节地址7CH是片内数据存储器中的一个地址单元,该地址单元中可以存放8位二进制数,位地址7CH是内部数据存储器中位寻址区中的一位,该地址单元中可以存放1位二进制数。位地址7CH具体在片内数据存储器字节地址为2FH中的第4位()。10、89S51/52中4个I/O
6、端口的作用是什么89S51/52的片外三总线是如何分配的答:I/O端口是单片机与外界联系的重要通道,实现与外部设备的信息的传输。总线分配:片外数据总线(8根)通过P0口输出,片外地址总线(16根)通过P0口(低8位)和P2口(高8位)输出,片外控制总线(PSEN ,ALE , RD ,WR ,EA)主要通过P3口。11、89S51/52中4个I/O端口在结构上有何异同89S51/52单片机的个I/O口在结构上是基本相同的,但又各具特点。这四个端口都是位双向口,每个端口都包括一个锁存器、一个输出驱动器和输入缓冲器。在无片外扩展存储器的系统中,这四个端口的每一位都可以作为双向通用I/O端口使用。在
7、作为一般的通用I/O输入时,都必须先向锁存器写入“”,使输出驱动场效应管FET截止,以免误读数据。各自特点如下:(1)P0口为双向8位三态I/O口,它既可作为通用I/O口,又可作为外部扩展时的数据总线及低8位地址总线的分时复用口。作为通用I/O口时,输出数据可以得到锁存,不需外接专用锁存器;输入数据可以得到缓冲,增加了数据输入的可靠性。每个引脚可驱动8个TTL负载。(数字电路按工艺有肖特基双极晶体管和CMOS工艺两种,使用双极晶体管的数字电路称TTL数字电路,单片机输出端带负载能力,意思就是单片机的P3端口只能并联4个TTL型集成电路输入端。)(2)P1口为8位准双向I/O口,内部具有上拉电阻
8、,一般作通用I/O口使用,它的每一位都可以分别定义为输入线或输出线,作为输入时,锁存器必须置1。每个引脚可驱动4个TTL负载。(3)P2口为8位准双向I/O口,内部具有上拉电阻,可直接连接外部I/O设备。它与地址总线高8位复用,可驱动4个TTL负载。一般作为外部扩展时的高8位地址总线使用。(4)P3口为8位准双向I/O口,内部具有上拉电阻,它是双功能复用口,每个引脚可驱动4个TTL负载。作为通用I/O口时,功能与P1口相同,常用第二功能。12、复位的作用是什么有几种复位方法复位后单片机的状态如何答:复位是单片机的初始化操作。单片机在RST引脚产生两个机器周期(即24个时钟周期)以上的高电平即可
9、实现复位。主要的复位方法有上电自动复位和按键手动复位两种。按键手动复位又分:按键电平复位和按键脉冲复位。第三章 指令系统1、简述下列名词术语的基本概念:指令、指令系统、程序、汇编语言指令答:指令:规定单片机进行某种操作的命令称为指令。指令系统:单片机能够执行的各种指令的集合。程序:一系列指令的有序集合称为程序。汇编语言指令:用助记符形式来表示机器指令。2、80C51单片机有哪几种寻址方式这几种寻址方式是如何寻址的答:共7种寻址方式,分别为:寄存器寻址,直接寻址,寄存器间接寻址,立即寻址,变址寻址,位寻址和相对寻址。寄存器寻址方式:由指令指出某一寄存器的内容做为操作数。直接寻址方式:指令中操作数
10、直接以单元地址的形式给出。寄存器间接寻址方式 :寄存器间接寻址方式,寄存器中存放的则是操作数的地址,即操作数是通过寄存器间接得到的。立即寻址方式:操作数在指令中直接给出。变址寻址方式:变址寻址是为了访问程序存储器中的数据和表格。MCS51的变址寻址是以DPTR或PC作基址寄存器,以累加器A作变址寄存器,并以两者内容相加形成的16位地址做为操作数地址,以达到访问数据和表格的目的。位寻址方式:指对片内RAM的位寻址区和某些可寻址的特殊功能寄存器进行位操作的寻址方式。相对寻址方式:相对寻址方式是为解决程序转移而专门设置的,为转移指令所采用。3、要访问特殊功能寄存器和片外数据寄存器,应采用哪些寻址方式
11、答:访问特殊功能寄存器可以采用直接寻址、寄存器寻址和位寻址(针对可以进行位寻址的特殊功能寄存器)方式。访问片外数据存储器可采用寄存器间接寻址方式。4、80C51单片机的指令系统可以分为哪几类说明各指令的功能。答:51单片机指令系统按功能可分为5类:(1)数据传送指令 主要进行数据的传送、交换等;(2)算术运算指令 主要进行基本的加减乘除运算;(3)逻辑运算指令 主要实现逻辑运算与移位运算; (4)控制转移指令 主要是实现对程序流程的控制;(5)位操作指令 5、外部数据传送指令有哪几条有和区别答:外部数据传送指令有读指令和写指令两类,每类指令的寻址范围不同,分别为:读外部存储器指令:MOVXA,
12、Ri;寻址范围为256字节MOVXA,DPTR;寻址范围为64K字节写外部存储器指令:MOVXRi,A;寻址范围为256字节MOVXDPTR,A;寻址范围为64K字节6、在89S51片内RAM中,已知(30H)=38H,(38H)=40H,(40H)=48H,(48H)=90H,请分别分析下段程序按序执行后的结果。MOVA,40H;A=48HMOV R0,A;R0=48HMOVP1,#0FFH;P1=FFHMOVR0,30H;(48H)=38HMOVDPTR,#1246H;DPTR=1246HMOV40H,38H;(40H)=40HMOVR0,30H;R0=38HMOV90H,R0;(90H)
13、=38HMOV 48H,#30H;(48H)=30HMOVA,R0;A=40HMOVP2,P1;P2=38H7、略8、DAA 指令的作用是什么怎样使用答:对十进制BCD数作加法时进行调整,当结果的低4位A0A3>9,或半进位AC=1,则A0A36,否则不加;当结果的高4位A4A7>9,或进位CY=1,则A4A76,否则不加;这条指令是在进行BCD码加法运算时,跟在“ADD”和“ADDC”指令之后,用来对BCD码的加法运算结果自动进行修正,使其仍为BCD码表示形式。9、试编程将片外数据存储器60H中的内容传送到片内RAM54H单元中。答:MOVR0,#60HMOVXA,R0MOV54
14、H,A10、试编程将寄存器R7的内容传送到R1中去。答:MOVA,R7MOVR1,A11、已知当前PC值为210H,请用两种方法将程序存储器2F0H中的常数送入累加器A中。答:(1)以程序计数器PC作为基址寄存器MOVA,#0E0HMOVCA,A+PC(2)以数据指针DPTR作为基址寄存器MOVDPTR,#02F0HMOVA,#00HMOVCA,A+DPTR12、试说明下段程序中每条指令的作用,并分析当指令执行完后,R0中的内容是什么MOVR0,#0A7H;R0=A7H,立即数送寄存器R0XCHA,R0;A=A7H,累加器A中的数据与R0中的数据进行交换SWAPA;A=7AH,累加器A中的高低
15、四位进行交换XCHA,R0;R0=7AH,数据交换回R013、请用两种方法实现累加器A与寄存器B的内容交换。答:(1)MOVR0,A MOVA,B MOVB,R0(2)MOVR0,B XCHA,R014、试编程将片外RAM中40H单元的内容与R1的内容交换。答:MOVR0,#40HMOVXA,R0XCHA,R1MOVXR0,A15、已知:A=0C9H,B=8DH,CY=1。执行指令 ADDCA,B结果如何 A=57H,CY=1,OV=1,AC=1,P=1执行指令 SUBBA,B结果如何 A=3BH,CY=0,AC=1,OV=116、试编程将片外RAM中30H和31H单元中的内容相乘,结果存放在
16、32H(低位)和33H(高位)单元中。答:MOVR0,#30HMOVXA,R0MOVB,AINCR0MOVXA,R0MULABINCR0MOVXR0,AMOVA,BINCR0MOVXR0,A17、试用3种方法将累加器A中的无符号数乘2.答:(1)MOVR0,A ADD A,R0(2)MOVB,#2 MULAB(3)RLA18、分析依次执行下列指令的结果:MOV30H,#0A4H;(30H)=A4HMOVA,#0D6H;A=D6HMOVR0,#30H;R0=30HMOVR2,#47H;R2=47HANLA,R2;A=46HORLA,R0 ;A=E6HSWAPA;A=6EHCPLA;A=91HXR
17、LA,#0FFH;A=6EHORL30H,A;(30H)=EEH19、求下列指令执行后,累加器A及PSW中进位CY、奇偶位P和溢出位OV的值。(1)当A=5BH时;ADDA,#8CH(2)当A=5BH时;ANLA,#7AH(3)当A=5BH时;XRLA,#7FH(4)当A=5BH,CY=1时;SUBBA,#0E8H答:(1)A=E7H,CY=1,P=0,OV=0 (2)A=5AH ,P=0 (3)A=24H ,P=0(4)A=72H,CY=1,P=0,OV=020、把累加器A中的低4位数据送到外部数据存储器的2000H单元。答:ANLA,#OFHMOVDPTR,#2000HMOVXDPTR,A
18、21、试说明指令CJNE R1,#7AH,10H的作用,若本指令地址为250H,其转移地址是多少答:指令作用:如果以R1内容为地址的单元中的数据等于7AH,则程序顺序执行,否则转移后继续执行。若本指令地址为250H,则转移地址为250H03H10H= 263H。22、将累加器A中的数据由0递增,加到50,结果在累加器A中。答:CLRAMOV R0,#50L1:INCADJNZR0,L123、试说明压栈指令和弹栈指令的作用及执行过程。答:压栈(入栈或进栈)指令的作用是将数据存入堆栈中,其执行过程是先将堆栈指针SP的内容加1,然后将直接地址单元中的数据压入SP指向的单元中。若数据已推入堆栈,则SP
19、指向最后推入数据所在的存储单元(即指向栈顶)。弹栈(出栈)指令的作用是将数据从堆栈中取出,其执行过程为先将堆栈指针SP所指出单元的内容送入直接寻址单元中,然后将SP的内容减1,此时SP指向新的栈顶。24、下述程序执行后,SP=,A=,B=。ORG2000HMOVSP,#40HMOVA,#30HLCALL250H;下条指令地址2008H送41H、42H,SP=42HADDA,#10HMOVB,A;地址为200AHL1:SJMPL1ORG250HMOVDPTR,#200AHPUSHDPL;SP+1=43H,DPL(43H)PUSHDPH;SP+1=44H,DPH(44H)RET;200AHPC答:
20、上述程序执行后,SP=42H,A=30H,B=30H。25、发光二极管点亮规律:先是第1和第8个亮,延时一段时间后,第2和第7个亮,延时后,再是第3和第6个亮,延时后,最后是第4和第5个点亮,延时后循环。26、若系统晶振频率为6MHz,求子程序DELAY的延时时间,若想加长或缩短时间,应该怎样修改答:DELAY:MOVR2,#0FAHL1:MOVR3,#0FAHL2:DJNZR3,L2DJNZ R2,L1RET总时间计算:T=4s(250×4s4s)×2504s=估算:T=250×4s×250=250ms若想加长延时时间,可以增加循环次数或再加一重循环;
21、若想减小延时时间,可以减少循环次数或较少一重循环。27、P1口连接8个共阳极连接的发光二极管,是编制灯亮移位程序。答:MOVA,#0FEHL1:MOVP1,ARLALCALLDELAY;DELAY子程序同上题SJMPL128、试编一程序,将外部数据存储器2100H单元中的高4位置“1”,其余位清“0”。答:MOVDPTR,#2100HMOVXA,DPTRORLA,#0F0HANLA,#0F0HMOVXDPTR,A29、试编程将片内数据存储器40H单元的第0为和第7位置1,其余取反。答:MOVA,40HCPLASETBSETBMOV40H,A30、将与80H位相与的结果,通过输出。MOVC,80
22、HANLC,MOV,C31、请用位操作指令,求下列逻辑方程。(1)MOVC,ORLC,ANLC,ORLC,/MOV,C(2)MOVC,ANLC,MOV20H,CMOVC,ANLC,/ORLC,20HMOV,C(3)MOVC,ANLC,/MOV20H,CMOVC,ANLC,/ORLC,20H (è下一行)MOV,C第四章 汇编语言程序设计1、编程将片内40H60H单元中的内容送到以3000H为首的存储区内。答:MOVR1,#40HMOVR2,#21HMOVDPTR,#3000HL1:MOVA,R1MOVXDPTR,AINCR1INCDPTRDJNZR2,L12、编程计算下列算式的程序(
23、1)23H+45H+ABH+03H=MOVA,#23HADDA,#45HADDA,#0ABHXCHA,B;溢出处理ADDCA,#00HXCHA,BADDA,#03H;A中为结果低位,B中为高位(2)CDH+15H-38H-46H=MOVA,#0CDHADDA,#15HSUBBA,#38HSUBBA,#46H(3)1234H+8347H=MOVA,#34HADDA,#47HMOV30H,AMOVA,#12HADDCA,#83HMOV31,A;30H存结果低位,31H存结果高位(4)AB123H-43ADCH=CLRCMOVA,#23HSUBBA,DCHMOV30H,AMOVA,#0B1HSUBB
24、A,#3AHMOV31H,AMOVA,#0AHSUBBA,#04HMOV32H,A;30H为低位,32H为高位3、设有两个4位BCD码,分别存放在23H、22H单元和33H、32H单元中,求他们的和,并送入43H、42H单元中(低位在低字节,高位在高字节)。答:MOVA,22HADDA,32HMOV42H,AMOVA,23HADDCA,33HMOV43H,A4、略5、编程计算片内RAM区50H59H单元中数的平均值,结果存放在5AH中。答:MOVR0,#8MOVR1,#50HMOVA,#00HL1:ADDA,R1INCR1DJNZR0,L1MOVB,#8DIVABMOV5AH,A6、编写计算下
25、式的程序。设乘积和平方结果均小于255。a 、b值分别存在片外3001H和3002H单元中,结果存于片外3000H单元中。(1) MOVDPTR,#3001HMOVXA,DPTRMOV30H,A;a暂存30H单元INCDPLMOVXA,DPTRCJNEA,30H,L1;是否a=bMOVA,#25SJMPSAVEL1:JNCL2MOVB,30HMULABSJMPSAVEL2:MOVB,AMOVA,30HDIVABSAVE:MOVDPTR,#3000HMOVXDPRT,A(2) MOVDPTR,#3001HMOVXA,DPTRMOV30H,AINCDPTRMOVXA,DPTRADDA,30HMOV
26、B,AMULAB; (ab)2MOV31H,ACJNEA,#10,L1SJMPSAVEL1:JCL2CLRCSUBBA,#10SJMPSAVEL2:ADDA,#10SAVE:MOVDPTR,#3000HMOVCDPTR,A7、设有两个长度均为15的数组,分别存放在以200H和210H为首地址的存储区中,试编程求其对应项之和,结果存放到以220H为首地址的存储区中。答:MOVDPH,#02HMOVR1,#15MOVR2,#00H; 数组1首地址低位MOVR3,#10H; 数组2首地址低位MOVR4,#20H; 和首地址低位L1:MOVDPL,R2MOVXA,DPTRMOVR1,AMOVDPL,R
27、3MOVXA,DPTRADDA,R1MOVDPL,R4MOVXDTPR,AINCR2INCR3INCR4DJNZR1,L1SJMP$8、设有100个无符号数,连续存放在以2000H为首地址的存储区中,试编程统计正数、负数和零的个数。答:MOV30H,#00H;正数计数器MOV31H,#00H;负数计数器MOV32H,#00H;零计数器MOVDPTR,#2000HMOVR1,#100L4:MOVXA,DPTRINCDPTRCJNEA,#0,L1INC32HSJMPL2L1:JCL3INC30HSJMPL2L3:INC31HL2:DJNZR1,L4SJMP$9、将片外数据存储器地址为1000H10
28、30H的数据块,全部搬迁到片内RAM 30H60H中,并将原数据块区域全部清零。答:MOV R0,#30HMOV R2,#31HMOV DPTR ,#1000HLP:MOVX A,DPTRMOV R0,AAND A,#00HMOVX DPTR,AINC R0INC DPTRDJNZ R2,LPSJMP$10、试编写一子程序,是R1、R0指向的两个片外RAM连续单元中的高4位二进制数,合并成一个字节,装入累加器A中。已知R0指向低地址,并要求该单元高四位放在A中高四位。答:MOVXA,R1ANLA,#0F0HSWAPAMOVR2,AMOVXA,R0ANLA,#0F0HORLA,R211、试编程把
29、以2040H为首地址的连续50个单元的无符号数按降序排列,存放到以3000H为首地址的存储区中。答:MOVR2,#50MOVR3,#20HMOVR4,#40H;源地址MOVR5,#30HMOVR6,#00H;目的地址SEND:MOVDPH,R3;SEND将2040H数据块移入3000H存储区MOVDPL,R4MOVXA,DPTRINCDPTRMOVR3,DPHMOVR4,DPLMOVDPH,R5MOVDPL,R6MOVXDPTR,AINCDPTRMOVR5,DPHMOVR6,DPLDJNZR2,SENDMOVR2,#49;重复次数CMP1:MOVDPTR,#3000HMOVR3,#49;比较次
30、数CMP2:MOVXA,DPTRMOVB,AINCDPTRMOVXA,DPTRCJNEA,B,L1L1:JCNOMOVEMOV30H,ACLRCMOVA,DPLSUBBA,#01HMOVDPL,AMOVA,30HMOVXDPTR,AINCDPTRMOVA,BMOVXDPTR,ANOMOVE:DJNZR3,CMP2;50个数重复一遍DJNZR2,CMP1;排序结束LJMP$12、试编一查表程序,从首地址为2000H,长度为100的数据块中找出ASCII码为A,将其地址送到20A0H和20A1H单元中。答:MOVDPTR,#2000HMOVR2,#100GO_ON:MOVXA,DPTRCJNEA,
31、#41H,IFENDMOVA,DPHMOVB,DPLMOVDPTR,#20A0HMOVXDPTR,AINCDPTRXCHA,BMOVXDPTR,ASJMPOVERIFEND:INCDPTRDJNZR2,GO_ONOVER:SJMPOVER13、设在200H204H单元中,存放5个压缩BCD码,编程将他们转换成ASCII码,存放到以205H单元为首地址的存储区。答:MOVR2,#05HMOVR3,#02HMOVR4,#00HMOVR5,#02HMOVR6,#05HCHLP:MOVDPH,R3MOVDPL,R4MOVXA,DPTRINCDPTRMOVR3,DPHMOVR4,DPLMOVB,ASWA
32、PAANLA,#0FHORLA,#30HMOVDPH,R5MOVDPL,R6MOVXDPTR,AINCDPTRMOVA,BANLA,#0FHORLA,#30HMOVXDPTR,AMOVR5,DPHMOVR6,DPLDJNZR2,CHLP14、有一无符号数据块长度在30H单元中,其首地址为31H单元,求出数据块中最大值,并存入40H中。答:MOVR0,#31HMOVR1,30HMOV40H,#00HLOOP:MOVA,R0CJNEA,40H,L1SJMPAGAINL1:JNCL2SJMPAGAINL2:MOV40H,AAGAIN:INCR0DJNZR1,LOOPSJMP$15、略16、在以200
33、0H为首地址的存储区内,存放20个用ASCII码表示的09之间的数,试编程,将它们转换成BCD码,并以压缩BCD码的形式存在3000H3009H单元中。答:MOVR2,#10MOVR3,#20HMOVR4,#00HMOVR5,#30HMOVR6,#00HLP:MOVDPH,R3MOVDPL,R4MOVXA,DPTRANLA,#0FHSWAPAXCHA,BINCDPTRMOVXA,DPTRANLA,#0FHORLA,BINCDPTRMOVR3,DPHMOVR4,DPLMOVDPH,R5MOVDPL,R6MOVXDPTR,AINCDPTRMOVR5,DPHMOVR6,DPLDJNZR2,LPSJM
34、P$17、试编程实现下列逻辑表达式功能。设为8个变量的输入端,而其中又作为变量的输出端。;输入端定义X0EQUX1EQUX2EQUX3EQUX4EQUX5EQUX6EQUX7EQU(1)MOVC,X0ANLC,X1ANLC,/X2ORLC,X3MOV00H,CMOVC,X4ANLC,X5ANLC,X6ORLC,/X7ORLC,00HMOV,C(2)MOVC,X0ANLC,X1CPLCMOV00H,CMOVC,X2ANLC,X3ANLC,X4CPLCMOV01H,CMOVC,X5ANLC,X6ANLC,X7CPLCORLC,O1HCPLCORLC,00HMOV,C18、略 19、略20、试编写延
35、时1s、1min、1h子程序。;单片机时钟fosc=12MHz,计算为近似值;1s延时子程序DLY_1S:MOVR0,#10L3:MOVR1,#200L2:MOVR2,#250L1:DJNZR2,L1DJNZR1,L2DJNZR0,L3RET;延时1minDLY_1M:MOVR3,#60L4:LCALLDLY_1SDJNZR3,L4RET;延时1hDLY_1H:MOVR4,#60L5:LCALLDLY_1MDJNZR4,L5RET21、用程序实现c=a2+b2。设a、b均小于10,a存在31H单元中,b存在32H单元中,c存33H单元。答:ORG1000HSR:MOVA,31HACALLSQR
36、MOVR1,AMOVA,32HACALLSQRADDA,R1MOV33H,ASJMP$;求平方子程序如下(采用查平方表的方法)SQR:INCAMOVCA, A+PC RETTABLE:DB 0, 1, 4, 9, 16DB 25,36,49,64,81END22、如何实现将内存单元40H60H的数逐个对应传到片外2540H2560H单元中答:MOVR0,#40HMOVDPTR,#2540HMOVR2,#21HL1:MOVA,R0MOVXDPTR,AINCR0INCDPTRDJNZR2,L1SJMP$23、参考21题24、参考21题25、参考实验程序26、参考实验程序第五章 定时/计数器1、89
37、S51单片机内部有几个定时/计数器,他们有哪些专用寄存器组成答:89S51单片机内部有两个16位定时/计数器,为定时器0(T0)和定时器1(T1)。在定时器/计数器的16位的计数器是由两个8位的专用寄存器TH0、TL0,TH1、TL1组成。2、89S51单片机的定时/计数器有哪几种工作方式,各有什么特点答:定时器/计数器有四种工作方式:方式0,方式1,方式2,方式3。其中,方式3只适用于T0。以T0为例:方式0,16位寄存器只用了13位,TL0的高三位未用。由TH0的8位和TL0的低5位组成一个13位计数器;方式1,和方式0的工作相同,唯一的差别是TH0和TL0组成一个16位计数器;方式2,把
38、TL0配置成一个可以自动恢复初值的8位计数器,TH0作为常数缓冲器。TH0由软件预置值。当TL0产生溢出时,一方面使溢出标志TF0置1,同时把TH0中的8位数据重新装入TL0中;方式3,将使TL0和TH0成为两个相互独立的8位计数器,TL0利用T0本身的一些控制,它的操作与方式0和方式1类似。而TH0被规定为只用作定时器功能,对机器周期计数,并借用了T1的控制位TR1和TF1。在这种情况下TH0控制了T1的中断。这时T1还可以设置为方式02,用于任何不需要中断控制的场合,或者用作串行口的波特率发生器。3、定时/计数器用作定时方式时,其定时时间与哪些因素有关作为计数时,对外界计数频率有何限制答:
39、定时/计数器作定时时,其计数脉冲由系统振荡器产生的内部时钟信号12分频后提供。定时时间与时钟频率和定时初值有关。定时/计数器作计数时,由于确认1次负跳变要花2个机器周期,即24个振荡周期,因此外部输入的计数脉冲的最高频率为系统振荡器频率的1/24。4、当定时器T0用作方式3时,由于TR1位已被T0占用,如何控制定时器T1的开启和关闭答:定时器T0用作方式3时,由于TR1位已被T0占用,此时通过控制位C/T切换其定时或计数器工作方式。当设置好工作方式时,定时器T1自动开始运行,若要停止,只需送入一个置定时器T1为方式3的方式字。5、已知89S51单片机系统时钟频率为24MHz,请利用定时器T0和
40、输出矩形脉冲。矩形波高电平宽度50µs,低电平宽度350µs。答:ORG 1000HMOV TMOD,02H ;设置工作方式MOV TH0,09CH;设置定时器初值MOV TL0,09CHSETB TR0;启动定时器LOOP:SETB;输出高电平MOVR0,07HDEL:JBC TF0,REP;定时是否到AJMP DELREP:SETB;输出低电平DJNZR0,DELAJMP LOOPEND6、在89S51单片机中,已知时钟频率为12MHz,请编程使和分别输出周期为2ms和500s的方波。答:选择方式2,用定时器T1MOVTMOD,#20HMOVTH1,#06HMOVTL1
41、,#06HSETBTR1L1:MOVR2,#04HL2:JNBTF1,$CLRTF1,CPLDJNZR2,L2CPLLJMPL17、设系统时钟为24MHz,试用定时器T0做外部计数器,编程实现每计到1000个脉冲,是T1开始2ms定时,定时时间到后,T0又开始计数,循环往复。答:MOVTMOD,#15H;T1定时方式1,T0计数方式1L1:MOVTH0,#0FCHMOVTL0,#18HSETBTR0JNBTF0,$CLRTR0CLRTF0MOVTH1,# HMOVTL1,# HSETBTR1JNBTF1,$CLRTR1CLRTF1LJMPL18、略9、略第六章 80C51的串行接口1、什么是串
42、行异步通信他有哪些特点有哪几种帧格式答:串行通信即所传输数据的各位按顺序一位一位的发送或接收。串行通信分为同步和异步两种方式。在异步通信中数据或字符是一帧一帧地传送的。帧定义为一个字符的完整的通信格式,通常也称为帧格式。它的主要特点:由于异步通信每传送一帧有固定的格式,通信双方只需按约定的帧格式来发送和接收数据,所以硬件结构比同步通信方式简单;此外它还能利用校验位检测错误。帧格式的一般形式是先用一个起始位“0”表示字符的开始,然后是数据位,其后是奇偶校验位,最后是停止位,用以表示字符结束。2、某异步通信接口按方式3传送,已知其每分钟传送3600个字符,计算其传送波特率。答:设每个字符由1个起始
43、位、8个数据位、1个可编程位和1个结束位组成,其传送波特率为: 11b×3600/60s=660bps3、80C51单片机的串行口由哪些基本功能部件组成答: 80C51单片机的串行口基本功能部件主要有:两个数据缓冲寄存器SBUF,一个串行口控制寄存器SCON,一个输入移位寄存器。4、80C51单片机的串行口有几种工作方式几种帧格式如何设置不同方式的波特率答:80C51单片机的串行口有四种工作方式,由串行口控制寄存器中的SM0、SM1控制。80C51单片机的串行通信有8位、10位、11位三种帧格式。波特率设置:4种工作方式波特率的计算方法不同,其中方式0和方式2的波特率是固定的,方式1
44、和方式3的波特率是可变的,均由定时器T1的溢出率控制。具体计算如下:方式0:波特率固定为时钟频率的1/12,不受SMOD的影响。(SMOD为波特率倍增位)方式1的波特率=2SMOD/32×定时器T1的溢出率 方式2的波特率=2SMOD/64×fosc方式3的波特率=2SMOD/32×定时器T1的溢出率5、为什么定时器T1用作串行口波特率发生器时,常采用工作方式2答:在串行通信中,收发双方对发送或接收的数据速率(即波特率)要有一定的约定。串口有四种工作方式,其中方式0和方式2的波特率是固定的,而方式1和方式3的波特率是可变的,有定时器T1的溢出率控制。定时器T1用作
45、串行口波特率发生器时,因为工作方式2是自动重装载方式,因而定时器T1作波特率发生器常采用工作方式2.6、已知定时器T1设置成方式2,用作波特率发生器,系统时钟频率为24MHz,求可能产生的最高和最低的波特率是多少答:最高波特率:TH1=0FFH,TL1=0FFH波特率最高=2/32×24M/(12×(256255)bps=最低波特率:TH1=00H,TL1=00H波特率最低=1/32×24M/(12×(2560)bps=244bps9、串行口异步通信时,ASCII码“3”的字符格式(10位)如何答:串行口异步通信时,10位的数据帧结构为:一个起始位(0)
46、,8个数据位(先低位后高位),一个停止位(1)。故ASCII码“3” 的字符格式为:01B。10、若选用定时器T1作波特率发生器,设fosc=6MHz,计数初值为0FDH,SMOD=1,求波特率是多少答:若选用定时器T1作波特率发生器,波特率由下式确定:波特率=(定时器T1溢出率)/n公式中:n为32或16,取决于特殊功能寄存器PCON中的SMOD位的状态。若SMOD=0,则n=32。若SMOD=1,则n=16。定时器T1溢出率=定时器T1的溢出次数/秒。由题可知:fosc=6MHz,计数初值为0FDH,SMOD=1,故第七章 中断系统1、什么是中断在单片机中中断能实现哪些功能答:中断是通过硬
47、件来改变CPU程序运行方向。计算机在执行程序过程中,由于CPU以外的原因,有必要尽快终止当前程序的执行,而去执行相应的处理程序,待处理结束后,在回来继续执行被终止的原程序。这种程序在执行过程中由于外界的原因而被中间打断的情况成为“中断”。中断能实现的功能:(1)能实现中断及返回。(2)能实现优先权的排队。(3)能实现中断的嵌套。2、什么是中断优先级中断优先级处理的原则是什么答:通常,在系统中会有多个中断源,有时会出现两个或更多个中断源同时提出中断请求的情况,这就要求计算机能区分各个中断源的请求,有能确定首先为哪一个中断源服务。为了解决这一问题,通常给各中断源规定了优先级别,称为优先权或中断优先
48、级。中断优先级处理原则:两个或两个以上的中断源同时提出中断申请时,计算机首先为中断优先权最高的中断服务,服务结束以后,再响应级别较低的中断源。3、80C51有几个中断源,各中断标志如何产生的,又如何清“0”的CPU响应中断时,中断入口地址各是多少答:8051单片机有5个中断源,分别是:外部中断0、定时器T0中断、外部中断1、定时器T1中断、串行口中断。中断标志产生与清“0”:(1)外部中断:外部中断由外部原因引起,可以通过两个固定的引脚()输入信号。一旦输入信号有效,则向CPU申请中断并使IE0(或IE1)=1。硬件复位。(2)定时器中断:定时器中断是为了满足定时或计数溢出处理的需要而设置的。当定时/计数器的计数结构发生计数溢出时,即表明定时时间到或计数次数到,此时就以计数器溢出信号作为中断请求,去置一个溢出标志位(TF0或TF1=1)。使用中断时通过硬件
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024标准员工固定期限劳动协议样本版
- 2024年规范化员工职位协议样本版
- 2025年度创新技术塔吊智能化改造及租赁合同3篇
- 06 野生保护 -把脉2021年中考英语作文热点【学科网名师堂】
- 2024生意合作协议合同范本:农产品批发市场合作框架协议2篇
- 2025年度原煤现货交易市场准入与交易合同3篇
- 2024年中学生教师节演讲稿范文(30篇)
- 2024设计公司保密协议书
- 动物学知到智慧树章节测试课后答案2024年秋云南大学
- KTV装修泥工施工合同模板
- 超短波操作流程图
- 小学2022 年国家义务教育质量监测工作方案
- 化学品安全技术说明(胶水)
- 南宁市中小学学籍管理系统数据采集表
- 中空吹塑成型课件
- 领先阅读X计划第四级Bug Hunt 教学设计
- 《诗词格律》word版
- 预算第二十三讲
- 高中体育与健康人教版全一册 6.2田径—短跑 课件(共11张PPT)
- 蔬菜供货服务保障方案
- WordA4信纸(A4横条直接打印版)
评论
0/150
提交评论