还剩19页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
第一章单片机概述
1.2除了单片机这一名称之外,单片机还可称为(微控制器)和(嵌入式控制器)
1.3单片机与普通计算机的不同之处在于其将(微处理器)、(存储器)和(各种输入输出接口)三部分集成于一块芯片上
4、单片机的发展大致分为哪几个阶段?答单片机的发展历史可分为四个阶段第一阶段(1974年----1976年)单片机初级阶段第二阶段(1976年----1978年)低性能单片机阶段第三阶段(1978年----现在)高性能单片机阶段第四阶段(1982年----现在)8位单片机巩固发展及16位单片机、32位单片机推出阶段
1.5单片机根据其基本操作处理的位数可分为哪几种类型?答单片机根据其基本操作处理的位数可分为1位单片机、4位单片机、8位单片机、16位单片机和32位单片机
1.6MCS-51系列单片机的基本芯片分别为哪几种?它们的差别是什么?答基本芯片为
8031、
8051、87518031内部包括1个8位cpu、128BRAM,21个特殊功能寄存器(SFR)、4个8位并行I/O口、1个全双工串行口,2个16位定时器/计数器,但片内无程序存储器,需外扩EPROM芯片8051是在8031的基础上,片内又集成有4KBROM,作为程序存储器,是1个程序不超过4KB的小系统8751是在8031的基础上,增加了4KB的EPROM,它构成了1个程序小于4KB的小系统用户可以将程序固化在EPROM中,可以反复修改程序
1.7MCS-51系列单片机与80C51系列单片机的异同点是什么?答共同点为它们的指令系统相互兼容不同点在于MCS-51是基本型,而80C51采用CMOS工艺,功耗很低,有两种掉电工作方式,一种是CPU停止工作,其它部分仍继续工作;另一种是,除片内RAM继续保持数据外,其它部分都停止工作
1.88051与8751的区别是(C)(A)内部数据存储单元数目的不同(B)内部数据存储器的类型不同(C)内部程序存储器的类型不同(D)内部的寄存器的数目不同
1.9在家用电器中使用单片机应属于微型计算机的(B)(A)辅助设计应用(B)测量、控制应用(C)数值计算应用(D)数据处理应用
1.10说明单片机主要应用在哪些领域?答单片机主要运用领域为工业自动化;智能仪器仪表;消费类电子产品;通信方面;武器装备;终端及外部设备控制;多机分布式系统第二章MCS-51单片机的硬件结构
2.1MCS-51单片机的片内都集成了哪些功能部件?各个功能部件的最主要的功能是什么?答功能部件如下微处理器(CPU);数据存储器(RAM);程序存储器(ROM/EPROM,8031没有此部件),4个8位并行I/O口(P0口、P1口、P2口、P3口);1个全双工的串行口;2个16位定时器/计数器;中断系统;21个特殊功能寄存器(SFR)各部件功能CPU(微处理器)包括了运算器和控制器两大部分,还增加了面向控制的处理功能,不仅可处理字节数据,还可以进行位变量的处理;数据存储器(RAM)片内为128B(52系列的为256B),片外最多可外扩64KB数据存储器来存储单片机运行期间的工作变量、运算的中间结果、数据暂存和缓冲、标志位等;程序存储器(ROM/EPROM)用来存储程序;中断系统具有5个中断源,2级中断优先权;定时器/计数器用作精确的定时,或对外部事件进行计数;串行口可用来进行串行通信,扩展并行I/O口,还可以与多个单片机相连构成多机系统,从而使单片机的功能更强且应用更广;特殊功能寄存器用于CPU对片内各功能部件进行管理、控制、监视
2.2说明MCS-51单片机的引脚EA的作用,该引脚接高电平和接低电平时各有何种功能?答当该引脚为高电平时,单片机访问片内程序存储器,但在PC(程序计数器)值超过0FFFH(对于
8051、8751)时,即超出片内程序存储器的4KB地址范围时,将自动转向执行外部程序存储器内的程序当该引脚为低电平时,单片机则只访问外部程序存储器,不论是否有内部程序存储器对于8031来说,因其无内部程序存储器,所以该引脚必须接地,这样只能选择外部程序存储器
2.3MCS-51的时钟振荡周期和机器周期之间有何关系?答每12个时钟周期为1个机器周期
2.4在MCS-51单片机中,如果采用6MHZ晶振,1个机器周期为(2微秒)
2.5程序存储器的空间里,有5个单元是特殊的,这5个单元对应MCS-51单片机5个中断源的中断入口地址,请写出这些单元的地址以及对应的中断源答中断源入口地址外部中断00003H定时器0(T0)000BH外部中断10013H定时器1(T1)001BH串行口0023H
2.6内部RAM中,位地址为30H的位,该位所在字节的字节地址为(26H)
2.7若A中的内容为63H,那么,P标志位的值为
(0)
2.8判断下列说法是否正确(A)8031的CPU是由RAM和EPROM所组成(错)(B)区分片外程序存储器和片外数据存储器的最可靠的方法是看其位于地址范围的低端还是高端(错)(C)在MCS-51中,为使准双向的I/O口工作在输入方式,必须保证它被事先预置为1(对)(D)PC可以看成是程序存储器的地址指针(对)
2.98031单片机复位后,R4所对应的存储单元的地址为(04H),因上电时PSW=(00H)这时当前的工作寄存器区是
(0)组工作寄存器区
2.10什么是机器周期?1个机器周期的时序是如何来划分的?如果采用12MHZ晶振,1个机器周期为多长时间?答CPU完成一个基本操作所需要的时间称为机器周期时序划分一个机器周期包括12个时钟周期,分为6个状态;S1-S6每个状态又分为2拍;P1和P2因此,1个机器周期中的12个时钟周期表示为S1P
1、S1P
2、S2P
1、S2P
2、…、S6P2如果采用12MHZ晶振,1个机器周期为1μs
2.11判断以下有关PC和DPTR的结论是否正确?(A)DPTR是可以访问的,而PC不能访问(错)(B)它们都是16位的寄存器(对)(C)它们都具有加1的功能(对)(D)DPTR可以分为2个8位寄存器使用,但PC不能(对)
12、内部RAM中,哪些单元可作为工作寄存器区,哪些单元可以进行位寻址?写出它们的字节地址答地址为00H-1FH的32个单元是4组通用工作寄存器区,每个区包括8个8位工作寄存器,编号为R0-R7字节地址为20H-2FH的16个单元可进行128位的位寻址,这些单元构成了1位处理机的存储器空间位地址范围是00H-7FH
2.13使用8031单片机时,需将EA引脚接(低)电平,因为其片内无(程序)存储器
2.14片内RAM低128个单元划分为哪3个主要部分?各部分的主要功能是什么?答字节地址为00H-1FH的32个单元是4组通用工作寄存器区,每个区包括8个8位工作寄存器,编号为R0-R7可以通过改变PSW中的RS
1、RS0来切换当前的工作寄存器区,这种功能给软件设计带来极大的方便,特别是在中断嵌套时,为实现工作寄存器现场内容保护提供了方便;字节地址为20H-2FH的16个单元可进行工128位的位寻址,这些单元构成了1位处理机的存储器空间;字节地址为30H-7FH的单元为用户RAM区,只能进行字节寻址用于作为数据缓冲区以及堆栈区
2.15判断下列说法是否正确(A)程序计数器PC不能为用户编程时直接使用,因为它没有地址(对)(B)内部RAM的位寻址区,只能供位寻址使用,而不能供字节寻址使用(错)(C)8031共有21个特殊功能寄存器,它们的位都是可用软件设置的,因此,是可以进行位寻址的(错)
2.16PC的值是(C)(A)当前正在执行指令的前一条指令的地址(B)当前正在执行指令的地址(C)当前正在执行指令的下一条指令的地址(D)控制器中指令寄存器的地址
2.17通过堆栈操作实现子程序调用,首先就要把(PC)的内容入栈,以进行断点保护调用返回时,再进行出栈保护,把保护的断点送回到(PC)
2.18写出P3口各引脚的第二功能答口引脚第二功能定义P
3.0串行输入口P
3.1串行输出口P
3.2外部中断0P
3.3外部中断1P
3.4定时器0外部计数输入P
3.5定时器1外部计数输入P
3.6外部数据存储器写选通P
3.7外部数据存储器读选通
2.19MCS-51单片机程序存储器的寻址范围是由程序计数器PC的位数所决定的,因为MCS-51的PC是16位的,因此其寻址的范围为
(64)KB
2.20当MCS----51单片机运行出错或程序陷入死循环时,如何来摆脱困境?答可通过复位来解决
2.21判断下列说法是否正确?(A)PC是1个不可寻址的特殊功能寄存器(对)(B)单片机的主频越高,其运算速度越快(对)(C)在MCS----51单片机中,1个机器周期等于1微秒(错)(D)特殊功能寄存器SP内装的是栈顶首地址单元的内容(错)
2.22如果手中仅有一台示波器,可通过观察哪个引脚的状态,来大致判断MCS----51单片机正在工作?答ALE引脚第三章MCS-51的指令系统
3.1判断以下指令的正误
(1)MOV28H,@R22DECDPTR3INCDPTR4CLRR05CPLR56MOVR0R17PUSHDPTR8MOVF0C9MOVF0Acc.310MOVXA@R111MOVC30H12RLCR0答
(3)、
(8)、
(10)、
(11)对,其余错
3.2判断下列说法是否正确(A)立即寻址方式是被操作的数据本身在指令中,而不是它的地址在指令中(√)(B)指令周期是执行一条指令的时间(√)(C)指令中直接给出的操作数称为直接寻址(×)
3.3在基址加变址寻址方式中,以(A)作变址寄存器,以(DPTR)或(PC)作基址寄存器
3.4MCS-51共有哪几种寻址方式?各有什么特点?答共有7种寻址方式
(1)寄存器寻址方式操作数在寄存器中,因此指定了寄存器就能得到操作数
(2)直接寻址方式指令中操作数直接以单元地址的形式给出,该单元地址中的内容就是操作数
(3)寄存器间接寻址方式寄存器中存放的是操作数的地址,即先从寄存器中找到操作数的地址,再按该地址找到操作数
(4)立即寻址方式操作数在指令中直接给出,但需在操作数前面加前缀标志“#”
(5)_______基址寄存器加变址寄存器间接寻址方式以DPTR或PC作基址寄存器,以累加器A作为变址寄存器,并以两者内容相加形成的16位地址作为操作数的地址,以达到访问数据表格的目的
(6)位寻址方式位寻址指令中可以直接使用位地址
(7)相对寻址方式在相对寻址的转移指令中,给出了地址偏移量,以“rel”表示,即把PC的当前值加上偏移量就构成了程序转移的目的地址
3.5MCS-51指令按功能可以分为哪几类?答MCS-51指令系统按功能分为数据传送类(28条);算术操作类(24条);逻辑运算类(25条);控制转移类(17条);位操作类(17条)
3.6访问SFR,可使用哪些寻址方式?答一般采用直接寻址,对于SFR中字节地址能被8整除的SFR可以使用位寻址,对于SFR中的A、B、DPTR寄存器可以采用寄存器寻址
3.7指令格式是由(操作码)和(操作数)所组成,也可能仅由(操作码)组成
3.8假定累加器A中的内容为30H,执行指令1000H MOVCA,@A+PC后,把程序存储器(1031H)单元的内容送入累加器中
3.9在MCS----51中,PC和DPTR都用于提供地址,但PC是为访问(程序)存储器提供地址,而DPTR是为访问(数据)存储器提供地址
3.10在寄存器间接寻址方式中,其“间接”体现在指令中寄存器的内容不是操作数,而是操作数的(地址)
3.11该程序段的功能是什么?PUSHAPUSHBPOPAPOPB答功能是A、B内容互换
3.12已知程序执行前有A=02H,SP=52H,(51H)=FFH,(52H)=FFH下列程序执行后POPDPHPOPDPLMOVDPTR#4000HRLAMOVBAMOVCA@A+DPTRPUSHAMOVABINCAMOVCA@A+DPTRPUSHARETORG4000HDB10H80H30H50H30H50HA=50HSP=50H(51H)=30H(52H)=50HPC=5030H
3.13写出完成如下要求的指令,但是不能改变未涉及位的内容(A)把Acc.3,Acc.4,Acc.5和Acc.6清0解ANLA,#87H(B)把累加器A的中间4位清0解ANLA,#C3H(C)使Acc.2和Acc.3置1解ORLA,#0CH
3.14假定A=83H,(R0)=17H,(17H)=34H,执行以下指令ANLA,#17HORL17H,AXRLA,@R0CPLA后,A的内容为(0CBH)
3.15假设A=55H,R3=0AAH,在执行指令后ANLA,R3后,A=(00H),R3=(0AAH)
3.16如果DPTR=507BH,SP=32H,(30H)=50H,(31H)=5FH,(32H)=3CH,则执行下列指令后POPDPHPOPDPLPOPSP则DPH=(3CH)DPL=(5FH)SP=(4FH)
3.17假定SP=60H,A=30H,B=70H,执行下列指令PUSHAPUSHB后,SP的内容为(62H),61H单元的内容为(30H),62H单元的内容为(70H)
3.18借助本书中的指令表表3-3~表3-7对如下的指令代码(16进制)进行手工反汇编FFC0E0E5F0F0解查表可知FFMOVR7,AC0E0PUSH0E0HE5F0MOVA,0F0HF0MOVX@DPTRA第四章MCS-51汇编语言程序设计
4.1用于程序设计的语言分为哪几种?它们各有什么特点?答用于程序设计的语言基本上分为三种机器语言、汇编语言和高级语言
(1)机器语言在单片机中,用二进制代码表示的指令、数字和符号简称为机器语言,直接用机器语言编写的程序称为机器语言程序用机器语言编写的程序,不易看懂,不便于记忆,且容易出错
(2)汇编语言具有如下特点A、汇编语言是面向机器的语言,程序设计人员必须对MCS----51单片机的硬件有相当深入的了解B、助记符指令和机器指令一一对应,所以用汇编语言编写的程序效率高,占用的存储空间小,运行速度快,因此用汇编语言能编写出最优化的程序C、汇编语言程序能直接管理和控制硬件设备(功能部件),它能处理中断,也能直接访问存储器及I/O接口电路
(3)高级语言高级语言不受具体机器的限制,都是参照一些数学语言而设计的,使用了许多数学公式和数学计算上的习惯用语,非常擅长于科学计算计算机不能直接识别和执行高级语言,需要将其“翻译”成机器语言才能识别和执行
4.3解释下列术语“手工汇编”、“机器汇编”、“交叉汇编”以及“反汇编”答、手工汇编通常把人工查表翻译指令的方法称为“手工汇编”机器汇编机器汇编实际上是通过执行汇编程序来对源程序进行汇编的交叉汇编由于使用微型计算机完成了汇编,而汇编后得到的机器代码却是在另一台计算机(这里是单片机)上运行,称这种机器汇编为“交叉汇编”反汇编有时,在分析现成产品的ROM/EPROM中的程序时,要将二进制数的机器代码语言程序翻译成汇编语言源程序,该过程称为反汇编
4.4下列程序段经汇编后,从1000H开始的各有关存储单元的内容将是什么?ORG1000HTAB1EQU1234HTAB2EQU3000HDB“MAIN”DWTAB1,TAB2,70H答(1000H)=‘M’(1001H)=‘A’(1002H)=‘I’(1003H)=‘N’(1004H)=34H(1005H)=12H(1006H)=00H(1007H)=30H(1008H)=70H(1009H)=00H
4.5设计子程序时注意哪些问题?答在编写子程序时应注意以下问题
(1)子程序的第一条指令的地址称为子程序的入口地址该指令前必须有标号
(2)主程序调用子程序,是通过主程序或调用程序中的调用指令来实现的
(3)注意设置堆栈指针和现场保护,因调用子程序时,要把断点压入堆栈,子程序返回执行RET指令时再把断点弹出堆栈送入PC指针,因此子程序结构中必须用堆栈
(4)子程序返回主程序时,最后一条指令必须是RET指令,它的功能是在执行调用指令时,把自动压入堆栈中的断点地址弹出送入PC指针中,从而实现子程序返回主程序断点处继续执行主程序
(5)子程序可以嵌套,即主程序可以调用子程序,子程序又可以调用另外的子程序,通常情况下可允许嵌套8层
(6)在子程序调用时,还要注意参数传递的问题
4.6试编写1个程序,将内部RAM中45H单元的高4位清0,低4位置1解MOVA,45HANLA,#0FHORLA,#0FH
4.7已知程序执行前有A=02H,SP=42H,(41H)=FFH,(42H)=FFH下述程序执行后,POPDPHPOPDPLMOVDPTR#3000HRLAMOVBAMOVCA@A+DPTRPUSHAMOVABINCAMOVCA@A+DPTRPUSHAORG3000HDB10H80H30H80H50H80HA=80HSP=40H(41H)=50H(42H)=80HPC=8050H
4.8计算下面子程序中指令的偏移量和程序执行的时间(晶振频率为12MHZ)7B0FMOVR3#15;1个机器周期7CFFDL1:MOVR4#255;1个机器周期8B90DL2:MOVP1R3;2个机器周期DCDJNZR4DL2;2个机器周期DBDJNZR3DL;2个机器周期22RET;2个机器周期解程序执行的时间为
15.346μs
4.9假定A=83H,(R0)=17H,(17H)=34H,执行以下指令ANLA,#17HORL17H,AXRLA,@R0CPLA后,A的内容为(0CBH)
4.10试编写程序,查找在内部RAM的30H~50H单元中是否有0AAH这一数据若有,则将51H单元置为“01H”;若未找到,则将51H单元置为“00H”ORG0000HMOVR0#30HMOVR2#21HLOOP:MOVA@R0CJNEA#0AAHNOTMOV51H#01HSJMPDENDNOT:INCR0DJNZR2LOOPMOV51H#00HDEND:SJMPDEND
4.11试编写程序,查找在内部RAM的20H~40H单元中出现“00H”这一数据的次数并将查找到的结果存入41H单元ORG0000HMOVR0#20HMOVR2#21HMOV41H#00HLOOP:MOVA@R0CJNEA#00HNOTEINC41HNOTE:INCR0DJNZR2LOOPEND
4.12若SP=60H,标号LABEL所在的地址为3456HLCALL指令的地址为2000H,执行如下指令2000HLCALLLABEL后,堆栈指针SP和堆栈内容发生了什么变化?PC的值等于什么?如果将指令LCALL直接换成ACLAA是否可以?如果换成ACALL指令,可调用的地址范围是什么?答堆栈指针SP的内容为62H,堆栈内容(61H)=03H,(62H)=20H;PC值为3456H不能将LCALL换为ACALL,因为LCALL可调用64KB范围内的子程序,而ACALL所调用的子程序地址必须与ACALL指令下一条指令的第一个字节在同一个2KB区内即16位地址中的高5位地址相同如果换为ACALL,可调用的地址范围为2002H-27FFH第五章MCS-51的中断系统
5.1什么是中断系统?答能够实现中断处理功能的部件称为中断系统
5.3什么是中断源?MCS-51有哪些中断源?各有什么特点?答产生中断的请求源称为中断源MCS----51中断系统共有5个中断请求源
(1)外部中断请求0,中断请求标志为IE0
(2)外部中断请求1,中断请求标志为IE1
(3)定时器/计数器T0溢出中断请求,中断请求标志为TF0
(4)定时器/计数器T1溢出中断请求,中断请求标志为TF1
(5)串行口中断请求,中断请求标志为TI或RI特点2个外部中断源,3个内部中断源
5.4外部中断1所对应的中断入口地址为(0013H)
5.5下列说法错误的是(A,B,C)(A)各中断源发出的中断请求信号,都会标记在MCS-51系统的IE寄存器中(B)各中断源发出的中断请求信号,都会标记在MCS-51系统的TMOD寄存器中(C)各中断源发出的中断请求信号,都会标记在MCS-51系统的IP寄存器中(D)各中断源发出的中断请求信号,都会标记在MCS-51系统的TCON和SCON寄存器中
5.6MCS-51单片机响应外部中断的典型时间是多少?在哪些情况下,CPU将推迟对外部中断请求的响应?答典型时间是3-8个机器周期在下列三种情况下,CPU将推迟对外部中断请求的响应
(1)CPU正在处理同级的或更高级优先级的中断
(2)所查询的机器周期不是当前所正在执行指令的最后一个机器周期
(3)正在执行的指令是RETI或是访问IE或IP的指令
5.7中断查询确认后,在下列各种8031单片机运行情况中,能立即进行响应的是(D)(A)当前正在进行高优先级中断处理(B)当前正在执行RETI指令(C)当前指令是DIV指令,且正处于取指令的机器周期(D)当前指令是MOVA,R
35.88031单片机响应中断后,产生长调用指令LCALL,执行指令的过程包括首先把(PC)的内容压入堆栈,以进行断点保护,然后把长调用指令的16位地址送(PC),使程序执行转向(响应中断请求的中断入口的地址)中的中断地址区
5.9编写出外部中断1为跳沿触发的中断初始化程序ORG0000HAJMPMAINORG0013HAJMPPINT1ORG0100HMAIN:SETBIT1SETBEX1SETBEAHERE:AJMPHEREPINT1:RETIEND
5.10在MCS-51中,需要外加电路实现中断撤除的是(D)(A)定时中断(B)脉冲方式的外部中断(C)外部串行中断(D)电平方式的外部中断
5.11MCS-51有哪几种扩展外部中断源的方法?答扩展外部中断源的方法有定时器/计数器作为外部中断源的使用方法;中断和查询结合的方法
5.12下列说法正确的是(CD)(A)同一级别的中断请求按时间的先后顺序顺序响应(B)同一时间同一级别的多中断请求,将形成阻塞,系统无法响应(C)低优先级中断请求不能中断高优先级中断请求,但是高优先级中断请求能中断低优先级中断请求(D)同级中断不能嵌套
5.13中断服务子程序返回指令RETI和普通子程序返回指令RET有什么区别?答两者的区别在于,RETI清除了中断响应时,被置1的MCS-51内部中断优先级寄存器的优先级状态
5.14某系统有3个外部中断源
1、
2、3,当某一中断源变为低电平时,便要求CPU进行处理,它们的优先处理次序由高到低依次为
3、
2、1,中断处理程序的入口地址分别为1000H,1100H,1200H试编写主程序及中断服务程序(转至相应的中断处理程序的入口即可)ORG0000HAJMPMAINORG0003HLJMPPINT0ORG0100HMAIN:SETBIT0SETBEX0SETBEAHERE:SJMPHEREPINT0:PUSHPSWPUSHAJNBP
1.3IR3JNBP
1.2IR2JNBP
1.1IR1PINTIR:POPAPOPPSWRETIIR3:LJMPIR3INTIR2:LJMPIR2INTIR1:LJMPIR1INTORG1000HIR3INT:LJMPPINTIRORG1100HIR2INT:LJMPPINTIRORG1200HIR1INT:LJMPPINTIREND第六章MCS-51的定时器/计数器
6.1如果采用的晶振的频率为3MHZ,定时器/计数器工作在方式
0、
1、2下,其最大的定时时间各为多少?答方式0213*4us=
32.768方式1216*4us=
262.144方式228*4us=
1.
0246.2定时器/计数器用作定时器时,其计数脉冲由谁提供?定时时间与哪些因素有关?答定时器/计数器被选定为定时器工作模式时,计数输入信号是内部时钟脉冲,每个机器周期产生1个脉冲使计数器增1,因此,定时器/计数器的输入脉冲的周期与机器周期一样,为时钟振荡频率的1/
26.3定时器/计数器作计数器使用时,对外界计数频率有何限制?答定时器/计数器用作计数器时,计数脉冲来自相应的外部输入引脚T0或T1对外界计数频率要求为其最高频率为系统振荡频率的1/
246.4采用定时器/计数器T0对外部脉冲进行计数,每计数100个脉冲后,T0转为定时工作方式定时1ms后,又转为计数方式,如此循环不止假定MCS---51单片机的晶体震荡器的频率为6MHZ,请使用方式1实现,要求编写出程序ORG0000HAJMPMAINORG000BHLJMPPT0JORG0100HMAIN:MOVTMOD#05H;00000001MOVTH0#0FFH;X=65436MOVTL0#9CHCLRF0SETBTR0SETBET0SETBEAHERE:AJMPHEREPT0J:JBF0PT0DMOVTMOD#01H;00000001MOVTH0#0FEH;X=65036MOVTL0#0CHSETBF0RETIPT0D:CLRF0MOVTMOD#05HMOVTH0#0FFHMOVTL0#9CHRETIEND
6.5定时器/计数器的工作方式2有什么特点?适用于哪些应用场合?答工作方式2为自动恢复初值的(初值自动装入)8位定时器/计数器,TLX作为常数缓冲器,当TLX计数溢出时,在置1溢出标志TFX的同时,还自动的将THX中的初值送至TLX,使TLX从初值开始重新计数(X=0,1)
6.6编写程序,要求使用T0,采用方式2定时,在P10输出周期为400微秒,占空比为110的矩形脉冲ORG0000HAJMPMAINORG000BHAJMPPT0ORG0100HMAIN:MOVR2#00HMOVTMOD#02HMOVTH0#0ECH;X=236MOVTL0#0ECHSETBP
1.0SETBTR0SETBET0SETBEAHERE:SJMPHEREPT0:CJNER2#09HPT01SETBP
1.0MOVR2#00HRETIPT01:CLRP
1.0INCR2RETIEND
6.7一个定时器的定时时间有限,如何实现两个定时器的串行定时,来实现较长时间的定时?答第一个定时溢出启动第二个定时计数,实行串行定时
6.8当定时器T0用于方式3时,应该如何控制定时器T1的启动和关闭?答控制信号C/T和M1M
06.9定时器/计数器测量某正脉冲的宽度,采用何种方式可得到最大量程?若时钟频率为6MHZ,求允许测量的最大脉冲宽度是多少?答上升沿从0开始计数,计满回到下降沿最大脉冲宽度Tw=
131.072us
6.10编写一段程序,功能要求为当P
1.0引脚的电平正跳变时,对P
1.1的输入脉冲进行计数;当P
1.2引脚的电平负跳变时,停止计数,并将计数值写入R
0、R1(高位存R1,低位存R0)ORG0000HLJMPMAINMAIN:ORG0100HMOVR0#00HMOVR1#00HMOVTL0#00HMOVTH0#00HLOOP1:JBP
1.0LOOP1LOOP2:JNBP
1.0LOOP2SETBTR0LOOP3:JNBP
1.2LOOP3LOOP4:JBP
1.2LOOP4CLRTR0MOVR1TH0MOVR0TL0END
6.11THX与TLX(X=0,1)是普通寄存器还是计数器?其内容可以随时用指令更改吗?更改后的新值是立即刷新还是等当前计数器计满之后才能更新?答THX与TLX(X=0,1)是计数器能用指令更改;能立即刷新
6.12判断下列说法是否正确?
(1)特殊功能寄存器SCON,与定时器/计数器的控制无关(√)
(2)特殊功能寄存器TCON,与定时器/计数器的控制无关(×)
(3)特殊功能寄存器IE,与定时器/计数器的控制无关(×)
(4)特殊功能寄存器TMOD,与定时器/计数器的控制无关(×)第七章MCS-51的串行口
7.3帧格式为1个起始位,8个数据位和1个停止位的异步串行通信方式是方式
(1)
7.4串行口有几种工作方式?有几种帧格式?各种工作方式的波特率如何确定?答串行口有四种工作方式方式
0、方式
1、方式
2、方式3有三种帧格式方式0帧格式方式0波特率=Fosc/12方式1帧格式方式1波特率=2SMOD定时器T1的溢出率/32方式2和方式3帧格式方式2的波特率=2MOD*Fosc/64方式3的波特率=2MOD*定时器T1的溢出率/
327.5假定串行口发送的字符格式为1个起始位,8个数据位,1个奇校验位,1个停止位,请画出传送字符“A”的帧格式?
7.6判断下列说法是否正确A串行口通行的第9数据位的功能可由用户定义(T)B发送数据的第9数据位的内容在SCON寄存器的TB8位中预先准备好的(T)C串行通讯帧发送时,指令把TB8位的状态送入发送SBUF中(F)(D)串行通讯接收到的第9位数据送SCON寄存器的RB8中保存(T)(E)串行口方式1的波特率是口变的,通过定时器/计数器T1的溢出率设定(T)
7.7通过串行口发送或接收数据时,在程序中应使用(C)(A)MOVC指令(B)MOVX指令(C)MOV指令(D)XCHD指令
7.8为什么定时器/计数器T1用作串行口波特率发生器时,常采用方式2?若已知时钟频率,通讯波特率,如何计算器初值答定时器T1工作方式2是一种自动重装方式,无需在中断服务程序中送数,没有由于中断引起的误差定时器工作在方式2是一种既省事又精确的产生串行口波特率的方法设定时器T1方式2的初值为X则有定时器T1的溢出率=计数速率/256-X=Fosc/256-X*12则方式2的波特率=2MOD*Fosc/256-X*12*32故计数器初值为X=2MOD*Fosc/12*32*波特率
7.9串行口工作方式1的波特率是C(A)固定的,为Fosc/32(B)固定的,为Fosc/16(C)可变得,通过定时器/计数器T1的溢出率设定(D)固定的,为Fosc/
647.10在串行通讯中,收发双方对波特率的设定应该是相同的
7.11若晶体振荡器为
11.0592MHZ串行口工作于方式1,波特率为4800b/s,写出用T1作为波特率发生器的方式控制字和计数初值答方式字为01000000Fosc=
11.0592MHzSMOD=1SCON=40HX=65536-
11.0592*2/384*4800=65524=0FFF4HORG0000HMOVSCON#40HMOVPCON#80HMOVTMOD#10HMOVTL1#0F4HMOVTH1#0FFHEND
7.14使用8031的串行口按工作方式3进行串行口数据通讯,假定波特率为1200b/s,第9数据位作奇偶校验位,以中断方式传送数据,请编写通讯程序方法一中断方式发送程序ORG0000HLJMPMAINORG0023HLJMPSSENDORG0100HMAIN:MOVSP#60HMOVTMOD#20HMOVTH1#0F3HMOVTL1#0F3HMOVR2#0FFHMOV87H#80HMOVSCON#0C0HMOVDPTR#2000HSETBTR1SETBESSETBEASEND:MOVXA@DPTRMOVCPMOVTB8CMOVSBUFAHERE:AJMPHERESSEND:DJNZR2SEND1AJMPRETURNSEND1:PUSHDPHPUSHDPLPUSHPSWPUSHACCSETB0D4HSETB0D3HCLRTIINCDPTRMOVXA@DPTRMOVCPMOVTB8CMOVSBUFAPOPACCPOPPSWPOPDPLPOPDPHCLR0D4HCLR0D3HRETURN:RETIEND接收程序ORG0000HLJMPMAINORG0023HLJMPRRESORG0100HMAIN:MOVSP#60HMOVTMOD#20HMOVTH1#0F3HMOVTL1#0F3HMOVR2#0FFHSETBTR1MOVDPTR#3000HMOV87H#80HMOVSCON#0D0HSETBESSETBEASJMP$RRES:DJNZR2RESAJMPRETURNRES:CLRRIMOVASBUFMOVCPJNCL1JNBRB8ERPAJMPL2L1:JBRB8ERPL2:MOVX@DPTRAINCDPTRAJMPRETURNERP:SETBP
1.0CPLP
1.0RETURN:RETIEND查询方式发送程序ORG0000HMAIN:MOVTMOD#20HMOVTH1#0F3HMOVTL1#0F3HMOV87H#80HMOVSCON#0C0HMOVDPTR#2000HMOVR2#0FFHSETBTR1SEND:MOVXA@DPTRMOVCPMOVTB8CMOVSBUFASTI:JNBTISTICLRTIINCDPTRDJNZR2SENDEND接收程序ORG0000HMOVTMOD#20HMOVTH1#0F3HMOVTL1#0F3HSETBTR1MOVDPTR#3000HMOV87H#80HMOVSCON#0D0HMOVR2#0FFHRES:JNBRIRESCLRRIMOVASBUFMOVCPJNCL1JNBRB8ERPAJMPL2L1:JBRB8ERPL2:MOVX@DPTRAINCDPTRDJNZR2RESERP:SETBP
1.0CPLP
1.0END
7.15某8031串行口,传送数据的帧格式为1个起始位
(0),7个数据位,1个偶校验位和1个停止位
(1)组成当该串行口每分钟传送1800个字符时,试计算出波特率答波特率=1800*(1+7+1+1)/60=300b/s
7.16为什么MCS-51串行口的方式0帧格式没有起始位
(0)和停止位
(1)?答因为方式0为同步移位寄存器输入输出方式,不需要起始和停止位,8位数据为1帧,依次移入输入式或输出移位寄存器第八章MCS-51单片机扩展存储器的设计
8.1单片机存储器的主要功能是存储(程序)和(数据)
8.2试编写一个程序(例如将05H和06H拼为56H),设原始数据放在片外数据区2001H单元和2002H单元中,按顺序拼装后的单字节数放入2002H参考源程序ORG0000HSTART:MOVB#10HMOVDPTR#2001HMOVXA@DPTRANLA#0FHMULABMOVBAMOVDPTR#2002HMOVXA@DPTRADDABMOVX@DPTRAEND
8.3假设外部数据存储器2000H单元的内容为80H执行下列指令后MOVP2#20HMOVR0#00HMOVXA@R0累加器A中的内容为(80H)
8.5在MCS-51单片机系统中,外接程序存储器和数据存储器共16位地址线和8位数据线,为何不发生冲突?答程序存储器和数据存储器虽然公用16位地址线和8位数据线,但由于数据存储器的读和写有/RDP
3.7和/WRP
3.6信号控制,而程序存储器有读选通信号/PSEN控制,因此,两者虽然共处同一地址空间,但由于控制信号不同,所以不会发生地址冲突
8.6区分MCS-51单片机片外程序存储器和片外数据存储器的最可靠的方法是:41看其位于地址范围的低端还是高端2看其离MCS-51芯片的远近3看其芯片的型号是ROM还是RAM4看其时与/RD信号连接还是与/PSEN信号连接
8.7在存储器扩展中,无论是线选法还是译码法,最终都是为扩展芯片的(片选)端提供的信号
8.9起始范围为0000H---3FFFH的存储器的容量是
(16)KB
8.10在MCS-51中,PC和DPTR都用于提供地址,但PC是为访问程序存储器提供地址,而DPTR是为访问(数据)存储器
8.1111根地址线可选
(2048)个存储单元,16KB存储单元需要
(14)根地址线
8.1232KBRAM存储器的首地址若为2000H则末地址为0FFFFH
8.14使用89C51芯片外扩1片E2PROM2864要求2864兼作程序存储器和数据存储器,且首地址为8000H,要求
(1)确定2864芯片的末地址;
(2)画出2864片选端的地址译码电路;
(3)画出该应用系统的硬件连线图第九章MCS-51扩展I/O接口的设计
9.1I/O接口和I/O端口有什么区别?I/O接口的功能是什么?答I/O端口简称为I/O口,常指I/O接口电路中具有端口地址的寄存器或缓冲器I/O接口是指单片机与外设间的I/O接口芯片一个I/O接口芯片可以有多个I/O端口,传送数据的称为数据口传送命令的称为命令口,传送状态的称为状态口当然,并不是所有的外设都需要三种接口齐全的I/O接口
9.2常用的I/O端口编址有哪两种方式?他们各有什么特点?MCS—51的I/O端口编址采用的是哪种方式?答有两种独立编址方式和统一编址方式独立编址方式就是I/O地址空间和存储器地址空间分开编址独立编址的优点是I/O地址空间的相互独立,界限分明但是,却需要设置一套专门的读写I/O的指令和控制信号;统一编址方式是把I/O端口的寄存器与数据存储器单元同等对待,统一进行编址同一编址方式的优点是不需要专门的I/O指令,直接使用访问数据存储器的指令进行I/O操作,简单、方便且功能强大MCS-51单片机使用的是I/O和外部数据存储器RAM同一编址的方式
9.3I/O数据传送有哪几种方式?分别在哪些场合下使用?答I/O数据传送的几种方式是同步传送、异步传送和中断传送
(1)同步传送方式又称为为条件传送当外设速度可与单片机速度相比拟时,常常采用同步传送方式,最典型的同步传送就是单片机和外部数据存储器之间的数据传送
(2)查询传送方式又称为与有条件传送,也称为异步传送单片机通过查询得知外设准备好后,再进行数据传送异步传送的优点是通用性好,硬件连线和查询程序十分简单,但是效率不高为了提高单片机的工作效率,通常采用中断传送方式3中断传送方式中断传送方式是利用MCS-51本身的中断功能和I./O接口的中断功能来实现I/O数据的传送单片机只有在外设准备好后,发出数据传送请求,才中断主程序,而进入与外设进行数据传送的中断服务程序,进行数据的传送中断服务完成后又返回主程序继续执行因此,采用中断方式可以大大提高单片机的工作效率.
9.4编写程序,采用8255A的C口按位置位/复位控制字,将PC7置0,PC4置1,(已知8255A各端口的地址为7FFCH-7FFFH)程序代码ORG0000HMOVDPTR#7FFFHMOVA#0EHMOVX@DPTRAMOVA#09HMOVX@DPTRAEND
9.78155H的端口都有哪些?哪些引脚决定端口的地址?引脚TIMERIN和/TIMEROUT的作用是什么?答8155H的端口为2个可编程的8位并行口PA和PB,1个可编程的6位并行口TIMERIN和/TIMEROUT TIMERIN是计数器输入线,输入的脉冲上跳沿用于对8155H片内的14位计数器减1/TIMEROUT为计数器输出线,当14位计数器减为0时就可以在该引线上输出脉冲或方波,输出信号的形状与所选的计数器工作方式有关
9.8判断下列说法是否正确,为什么?
(1)由于8155H不具有抵制锁存功能,因此在与8031的接口电路中必须加地址锁存器
(2)在8155H芯片中,决定端口和RAM单元编址的信号线是AD7-AD0和/WR
(3)8255A具有三态缓冲器,因此可以直接挂在系统的数据总线上
(4)8255A的B口可以设置成方式2这四个命题都是错误的
9.9现有一片8031,扩展了一片8255A若把8255A的B口用作输入,B口的每一位接一个开关,A口用作输出,每一位接一个发光二极管,请画出电路原理图,并编写B口某一位开关接高电平时,A口相应位二极管被点亮的程序ORG0000HMOVDPTR#0003HMOVA#82HMOVX@DPTRAMOVDPTR#0001HMOVXA@DPTRMOVDPTR#0000HMOVX@DPTRAEND
9.10假设8155H的TIMERIN引脚输入的频率为4MHz?问8155H的最大定时时间是多少?答T=214*(1/4MHz)=4096μs
9.11MCS-51的并行接口的扩展有多种方法,在什么情况下,采用扩展8155H比较合适?什么情况下,采用扩展8255A比较适合?答需扩展RAM和I/O需用8155H,仅扩展I/O用8255H
9.12假设8155H的TIMERIN的引脚输入的脉冲频率为1MHz,请编写出在8155H的/TIMEROU引脚上输出周期为10ms的方波的程序8155端口地址为7F00H-7F05H程序代码ORG0000HMOVDPTR#7F04HMOVA#0E8HMOVX@DPTRAINCDPTRMOVA#40HMOVX@DPTRAMOVDPTR#7F00HMOVA#0C0HMOVX@DPTRAEND第十章MCS-51与键盘、显示器的接口设计
10.1为什么要消除按键的机械抖动?消除按键的机械抖动的方法有哪几种?原理是什么?答为了确保CPU对一次按键动作只确认一次按键有效,所以必须消除抖动常采用软件来消除按键抖动,其基本思想是在第一次检测到有键按下时,该键所对应的行线为低点平,执行一段延时10ms的子程序后,确认该行线电平是否仍为低点平,如果仍为低点平,则确认为该行确实有键按下当按键松开时,行线的低电平变为高电平,执行一段延时10ms的子程序后,检测该行线为高电平,说明按键确实已经松开
10.3LED的静态显示方式与动态显示方式有何区别?各有什么优缺点?答详见书本P228-P
23010.5说明矩阵式键盘按键按下的识别原理答详见书本P
23410.7键盘有哪三种工作方式?它们各自的工作原理及特点是什么?答详见书本P236-P
23710.9根据图10-14的电路,编写在6个LED显示器上轮流显示“1,2,3,4,5,6”的显示程序.MOVR2,#06HMOVR0,#79HMOVA,#01HLOOP MOV@RO,AINCAINCR0DJNZR2,LOOP以下代码见P239接DIR MOVR9,#79HMOVR3,#01H第十一章MCS-51单片机与A/D、D/A转换器的接口
11.1对于电流输出的D/A转换器,为了得到电压的转换结果,应使用(由运算放大器构成的电流/电压转换电路)
11.2D/A转换器的主要性能指标有哪些?设某DAC为二进制12位,满量程输出电压为5V,试问它的分辨率是多少?答D/A转换器的主要性能指标分辨率、建立时间、精度它的分辨率为5V/212=
1.220703125mv
11.3说明DAC用作程控放大器的工作原理答DAC用作程控放大器的工作原理详见P
28311.4使用双缓冲方式的D/A转换器,可以实现多路模拟信号的(同时)输出
11.5MCS-51与DAC0832接口时,有哪三种连接方式?各有什么特点?各适合在什么场合使用答单缓冲,双缓冲,直通单缓冲两个数据缓冲器有一个处于直通方式,另一个受控锁存锁存方式,应用只有一路输出,或多路,不需求同步双缓冲数字量的输入锁存和DAC转换输出分两步完成,适用多路准环的同步输出直通所有控制信号均有效,适用于连续反馈控制电路
11.7分析A/D转换器产生量化误差的原因,1个8位的A/D转换器,当输入电压为0-5V时,其最大的量化误差是多少?答量化过程引起的误差.量化误差是由于有限位数字量对模拟量进行量化而引起的误差,提高分辨率可以减少量化误差△=+LSB/2=+1/2*5/28=+
9.77mv
11.12判断下列说法是否正确?1)转换速率这一指标仅适用于A/D转换器,D/A转换器不用考虑转换速率这一问题(F)2)ADC0809可以利用转换结束信号EOC向8031发出中断请求(T)3)输出模拟量的最小变化量称为A/D转换器的分辨率(F)D1D2D3D4D5D6D7D0停止位起始位D7D6D5D4D3D2D1D0D1D2D3D4D5D6D7D0停止位起始位D800000101011。