单片机应用技术思考题及习题

上传人:沈*** 文档编号:41033866 上传时间:2021-11-18 格式:DOC 页数:22 大小:418.50KB
返回 下载 相关 举报
单片机应用技术思考题及习题_第1页
第1页 / 共22页
单片机应用技术思考题及习题_第2页
第2页 / 共22页
单片机应用技术思考题及习题_第3页
第3页 / 共22页
点击查看更多>>
资源描述
第一章思考题与习题1. 什么叫嵌入式系统?与单片机的关系如何?以应用为中心,以计算机技术为基础,软硬件可裁剪,针对具体应用系统,对功能、可靠性、成本、体积、功耗严格要求的专用计算机系统被称为嵌入式系统。单片机又称嵌入式微控制器,是嵌入式系统应用的主流。2. 单片机主要应用在哪些方面? 单片机主要应用在工业、智能仪表、军事导航、电信、日常生活、办公自动化、汽车电子、消费电子等方面。3. 单片机系统的开发过程分几步进行?单片机的应用开发可分为五个过程,总体方案设计、硬件单元电路设计与制作、应用程序的设计与调试、系统联调、固化(烧写)与脱机运行。4. 下表每一行给出了一种数制的无符号数,试将它转换为其他两种数制,并填入表中。二进制十进制十六进制010110011B1790B3H110010010B402192H11110101B2450F5H01101100B1086CH11111111B2550FFH01110110B11876H5. 试写出下列真值所对应的机器数。(1)+1010011 (2)-1011010(3)+0101110(4)-0111111以8位二进制补码表示为:(1)11010011(2)10100110(3)10101110(4)110000016. 试写出下列机器数所对应的真值。(1)11000000(2)01111111(3)01011011(4)11111111(1)-64(2)+127(3)+91(4)-17. 下表每一行给出原码、反码或补码中的一个值,试求出其它两个码,并填入下表中。原码反码补码01111111B01111111B01111111B10000000B11111111B00000000B10001111B11110000B11110001B01010101B01010101B01010101B10000010B11111101B0FEH00000011B00000011B03H8. 将下列有符号数的二进制补码转换为十进制数,并注明它的正负。(1)11111111B(2)01111111B(3)10000011B(4)11111100B(5)00000011B(6)01111100B(1)-1(2)+127(3)-125(4)-4(5)+3(6)+1249. 一个字节的十六进制数最大值相当于多大的十进制数,两个字节的十六进制数最大值相当于多大的十进制数?一个字节十六进制数最大值为0FFH,相当于十进制数255,两个字节的十六进制数最大值为0FFFFH,相当于十进制数65535。第二章思考题与习题1. 微型计算机由哪几个功能部件组成?各功能部件的作用如何?微型计算机由CPU、三总线、存储器、I/O接口电路及外围设备组成。CPU作为系统的运算中心和控制中心;三总线用于完成微处理器、内存储器和I/O接口电路之间信息的相互交换;存储器用于程序与数据的存储;I/O接口电路作为CPU与外部设备的联接桥梁,用于信号的标准化;外围设备可实现显示、输入、打印、通信等功能。2. 三总线是指什么?它们的主要功能是什么?三总线是指数据总线(Data Bus)、地址总线(Address Bus)和控制总线(Control Bus)。数据总线(DB)的功能是完成微处理器与内存、I/O接口电路之间的数据传送;地址总线(AB)是微处理器向内存和I/O接口电路传送地址信息的通路;控制总线(CB)是微处理器向内存和I/O接口电路发出的命令信息或由外界向微处理器传送状态的信息通路。3. 微型计算机存储器的地址线与存储容量有什么关系?如果存储器的地址线有13根,则存储容量为多大?地址线的多少与存储容量的关系满足:存储容量=2n(n为地址线的数量),如果存储器的地址线有13根,则存储容量为8KB。4. 89S51单片机的存储器从物理结构上分别可划分为几个空间?89S51单片机的存储器在物理结构上有4个存储空间:片内程序存储器、片外程序存储器、片内数据存储器、片外数据存储器。5. 89S51单片机采用何种方式区分内外程序存储器及内外数据存储器?单片机的程序存储器是在片内存储器还是片外存储器,取决于单片机外围引脚的状态。片内和片外数据存储器采用不同的指令加以区别,在访问片内数据存储器时,可使用MOV指令;要访问片外数据存储器可使用MOVX指令。6. 89S51单片机内部数据存储器分为几个空间?每个空间有何特点?89S51单片机的内部数据存储器分为007FH及80HFFH两块空间。片内数据存储区地址为007FH空间划分为工作寄存器区、位寻址区及用户RAM区三个空间;80HFFH地址空间中只有26个存储空间被特殊功能寄存器(SFR)占用。工作寄存器区共32个存储单元,分为4组,每组由8个地址单元组成通用寄存器R0R7,每组寄存器均可作为CPU当前的工作寄存器。位寻址区共16个字节,每个字节8位,共128位,这128位用位地址编号,范围为00H7FH,位寻址区既可采用位寻址方式访问,也可以采用字节寻址方式访问。用户RAM区共80个单元,可作为堆栈或数据缓冲使用。特殊功能寄存器SFR专门用来设置单片机内部的各种资源,记录电路的运行状态,参与各种运算及输入/输出操作。7. 程序状态字PSW的作用是什么?常用状态位是哪些?作用是什么?程序状态字PSW用来存放与当前指令执行结果相关的状态。常用的状态位有CY、AC、OV、P、RS1、RS0等。CY用于标志运算过程中是否有进位或借位;AC用于标志累加器中D3位向D4位是否存在进位或借位;OV用于标志有符号数运算过程中是否存在超出范围的情况;P用于指示累加器A中操作结果的“1”的个数的奇偶性,在串行通信中做数据校验;RS1、RS0用于选择工作寄存器组别。8. 89S51单片机内部有几个特殊功能存储单元?分别有何用途?89S51单片机内部有26个特殊功能存储单元,各自用途请参见表2-3。9. 89S51单片机复位后,CPU使用的是哪一组工作寄存器?它们的字节地址分别是什么?CPU如何确定和改变当前工作寄存器组?89S51单片机复位后,CPU使用的是第0组工作寄存器,它们的字节地址为00H07H。CPU通过标志寄存器中的RS1、RS0两位状态确定和改变当前工作寄存器组。10. 89S51单片机的4个I/O端口P0P3在结构上有何异同?使用时应注意什么?89S51各端口中P0口既可作地址/数据总线口,又可作通用I/O口。在作地址/数据总线口时,它是真正的双向口,可以直接驱动MOS输入,不需要加上拉电阻。当它作通用I/O口时,应注意必须外接上拉电阻才能驱动MOS输入。对P1、P2、P3口而言,内部已接有上拉电阻,因此不必外接任何电阻就可驱动MOS输入。P0口和P1、P2、P3口作通用I/O口时一样,在输入时分为“读锁存器”和“读引脚”两种操作,这两种操作是用不同的指令区分的。11. 简述89S51中下列各引脚信号的作用:、ALE:读信号 :写信号 :读片外部程序存储器选通信号 :片外程序存储器选择信号 ALE:地址锁存允许信号12. 什么是时钟周期、机器周期、指令周期?它们之间有何关系?时钟电路产生的最小时序单位称为时钟周期;单片机执行一次基本操作所需要的时间单位为一个机器周期;单片机执行一条指令所需要的时间称为指令周期。1个机器周期=12个时钟周期,1个指令周期,通常由14个机器周期组成。13. “复位”的含义是什么?89S51单片机常用的复位电路有哪些?复位后各内部存储器的值分别为多少?复位就是对单片机进行初始化操作,使单片机内部各寄存器处于一个确定的初始状态。89S51单片机常用的复位电路有上电复位和按钮复位两种。复位后SP为07H,P0P3为0FFH,SBUF不定,除SP、P0P3及SBUF外,其余各寄存器值均为0。第三章思考题与习题1. MCS-51单片机指令格式是怎样的?各有何含义?汇编语言表示的指令格式为:标号:操作码助记符操作数1,操作数2, 操作数3 ;注释 标号:表示该指令所在的地址。操作码:表示该语句要执行的操作内容。操作数:表示操作码的操作对象。注释:为阅读程序方便而加的解释说明。2. MCS-51单片机有几种寻址方式?描述这些寻址方式的执行过程?MCS-5l系列单片机共有7种寻址方式,立即寻址、直接寻址、寄存器寻址、寄存器间接寻址、相对寻址、变址寻址、位寻址。立即寻址:操作数直接由指令给出,寻址时直接到程序存储器中查找操作数。直接寻址:操作数在指令给出的地址单元中,寻址时直接到数据存储器中查找操作数。寄存器寻址:所需查找的操作数在寄存器中。寄存器间接寻址:所要查找的操作数位于以寄存器的内容为地址的单元中。寻址时从寄存器中查找的值做为地址再次查找操作数。相对寻址:不是寻找操作数的地址,而是要得到程序跳转位置对应的目标地址。变址寻址:以16位寄存器(数据指针DPTR或程序计数器指针PC)作为基址寄存器,以累加器A作为变址寄存器,并以两者内容相加形成新的16位地址作为操作数所在的地址,查找操作数。位寻址:将位地址中的内容做为操作数。3. 指出在下列各条指令中,30H分别代表什么含义?MOVA, #30H;为立即数MOVA, 30H;为直接地址MOV30H, #30H;30H为直接地址,#30H为立即数MOV30H, 28H;30H为直接地址MOVC, 30H;为位地址4. 设(A)=0FH,(R0)=30H,内部RAM的(30H)=12H,(31H)=0BH,(32H)=0CH, 请指出每条指令中源操作数的寻址方式,并写出执行下列程序段后上述各单元内容的变化结果。MOV A, R0;寄存器间接寻址,(A)=12HMOV R0, 32H;直接寻址,(30H)=0CHMOV 32H, A;寄存器寻址,(32H)=12HMOV R0, #31H;立即寻址,(R0)=31HMOV A, R0;寄存器间接寻址,(A)=0BH5. 用指令实现下列数据传送。(1)内部RAM 20H单元内容送内部RAM 30H单元。MOV30H,20H(2)外部RAM 20H单元内容送内部RAM 30H单元。MOVR0,#20HMOVXA,R0MOV30H,A(3)外部RAM 1000H单元内容送寄存器R2中。MOVDPTR,#1000HMOVXA,DPTRMOVR2,A(4)内部RAM 20H单元内容送外部RAM 1000H单元。MOVA,20HMOVDPTR,#1000HMOVXDPTR,A(5)外部RAM 20H单元内容送外部RAM 1000H单元。MOVR0,#20HMOVXA,R0MOVDPTR,#1000HMOVXDPTR,A(6)ROM 2000H单元内容送内部RAM 30H单元。MOVDPTR,#2000HCLRAMOVCA,A+DPTRMOV30H,A(7)ROM 2000H单元内容送外部RAM 20H单元。MOVDPTR,#2000HCLRAMOVCA,A+DPTRMOVR0,#20HMOVXR0,A(8)ROM 2000H单元内容送外部RAM 1000H单元。MOVDPTR,#2000HCLRAMOVCA,A+DPTRMOVDPTR,#1000HMOVXDPTR,A6. 设(A)= 5AH,(R0)=20H,(20H)=6BH,(B)=02H,(PSW)=80H。写出下列指令执行后的结果及对标志位的影响。(每条指令都以题中规定的原始数据参加操作)。(1)ADD A,R0;(A)=7AH,(PSW)=01H(2)ADDCA,20H;(A)=0C6H,(PSW)=44H(3)SUBB A,#20H ;(A)=39H,(PSW)=00H(4)INC A;(A)=5BH,(PSW)=81H(5)MUL AB ;(A)=0B4H,(B)=00H,(PSW)=00H(6)DIVAB;(A)=2DH,(B)=00H,(PSW)=00H(7)ANL 20H,#45H ;(20H)=41H,(PSW)=80H(8)ORLA,#32H;(A)=7AH,(PSW)=81H(9)XRL 20H,A ;(20H)=31H,(PSW)=80H(10)XCHA,20H;(A)=6BH,(20H)=5AH,(PSW)=80H(11)SWAPA ;(A)=0A5H,(PSW)=80H(12)CPL A;(A)=0A5H,(PSW)=80H(13)RR A ;(A)=2DH,(PSW)=80H(14)RLC A;(A)=0B5H,(PSW)=01H7. 写出执行下列程序段的运行结果。 (1)MOVA,#20HMOV DPTR,#2030HMOVX DPTR,AMOV 30H,#50HMOV R0,#30HMOVX A,R0 外部RAM(2030H)=20H,(DPTR)=2030,(30H)=50H,(R0)=30H,(A)=0FFH(2)MOV A,#79HMOV 20H,#88HADD A,20HDA ASWAPA内部RAM(20H)=88H,(A)=76H,(PSW)=0C1H8. 试写出达到下列要求的程序。(1)将外部RAM 1000H单元中的低4位清0,其余位不变,结果存回原处。DPTR,#1000HMOVXA,DPTRANLA,#0F0HMOVXDPTR,A(2)将内部RAM 50H单元中的高3位置1,其余位不变,结果存回原处。ORL50H,#0E0H(3)将内部RAM 20H单元中的高4位置1,低4位清0,结果存回原处。ANL20H,#0F0HORL20H,#0F0H(4)将DPTR的中间8位取反,其余位不变,结果存回原处。XRLDPL,#0F0HXRLDPH,#0FH9. 用三种方法实现累加器A中的无符号数乘2运算。(1)MOVR0,AADDA,R0(2)MOVB,#02HMULAB(3)CLRCRLA10. 编程实现两个16位二进制数8E52H、47A4H相减的运算,结果放在内部RAM的20H与21H单元中,前者放低8位,后者放高8位。CLRCMOVA,#52HSUBBA,#0A4HMOV20H,AMOVA,#8EHSUBBA,#47HMOV21H,A11. SJMP 指令和AJMP指令都是两字节转移指令,它们有什么区别?各自的转移范围是多少?能否用AJMP代替SJMP?为什么?两条指令区别在于转移范围不同,SJMP转移范围256B,AJMP转换范围2K,通常可以用AJMP代替SJMP,AJMP的转移范围比SJMP转换范围大,但必须保证地址前5位不变。12. 已知(SP)=35H,(34H)=12H,(35H)=34H,(36H)=56H。问此时执行“RET”指令后,(SP)=? (PC)=?(SP)=33H,(PC)=1234H13. 若(SP)=35H,(PC)=2345H,标号LOOP所在的地址为3456H。执行长调用指令“LCALL LOOP”后,堆栈指针和堆栈的内容发生什么变化?PC的值为多少?若将上述指令改为“ACALL LOOP”是否可以?为什么?(SP)=37H,(36H)=48H,(37H)=23H,(PC)=3456H若将上述指令改为“ACALL LOOP”是不行的,因为“ACALL”指令只能在2K范围内调用。 14. 试编写程序完成将内部RAM 30H为首地址的20个数据传送至外部RAM以1000H为首地址的区域中。MOVR0,#30HMOVDPTR,#1000HMOVR7,#20LOOP:MOVA,R0MOVXDPTR,AINCR0INCDPTRDJNZR7,LOOPRET15. 试编程实现:若累加器A的内容为正数,则将内部RAM 20H单元内容清零,否则置FFH。MOV20H,#00HJNBACC.7,LOOPMOV20H,#0FFHLOOP:RET16. 试编程实现:查找内部RAM的20H50H单元中出现00H的次数,并将查找结果存入R1单元。MOVR0,#20HMOVR7,#31HMOVR1,#00HLOOP:MOVA,R0JNZNZEROINCR1NZERO:INCR0DJNZR7,LOOPRET第四章思考题与习题1. 汇编语言程序设计分哪几个步骤?汇编语言程序设计一般有以下几步:(1)分析问题,明确任务;(2)确定算法;(3)制订程序流程图;(4)编写源程序;(5)汇编与调试。2. 什么叫“伪指令”?伪指令与指令有什么区别?它们的用途是什么?伪指令是指在单片机的指令系统中为汇编程序提供相关信息的特定指令。与指令不同之处在于,伪指令在汇编时不产生目标代码,不影响程序执行。它们主要用于为汇编程序提供汇编的信息,例如为程序指定起始点和结束点等。3. 基本程序结构有哪几种?各有什么特点?基本程序结构主要有顺序结构、分支结构和循环结构三种。顺序结构是从第一条指令开始依次执行每一条指令,直到执行完毕。分支结构是通过对条件是否满足的判断,产生一个或多个分支以决定程序的流向。循环结构是可对同一组操作重复执行多次的程序结构。4. 试对下列程序进行汇编,并用流程图说明程序的功能。ORG 0100HMOV A,30HJNB ACC.7,ZHENGCPL AADD A,#01HORLA,#80HZHENG:MOV 32H,ASJMP $END该程序的功能:对30H中的数据进行求补运算,并将结果存入32H单元。5. 子程序调用时,参数的传递方法有哪几种?子程序调用时,参数传递方法有三种:(1)通过工作寄存器或累加器传递参数;(2)通过指针寄存器传递参数;(3)通过堆栈传递参数。6. 设内部RAM 50H和51H单元中存放有二个8位有符号数,试编程找出其中的大数,将其存入60H单元中。ORG0100HMOVA,50HXRLA,51HJBACC.7,LOOPMOVA,50HCLRCSUBBA,51HJCLOOP1MOV60H,50HSJMPERETLOOP1:MOV60H,51HSJMPERETLOOP:MOVA,50HJBACC.7,LOOP1MOV60H,50HERET:SJMP$END7. 编程将外部RAM 2000H202FH单元中的内容,移入内部RAM 20H4FH单元中,并将原数据块区域全部清0。ORG0100HMOVDPTR,#2000HMOVR0,#20HMOVR7,#30HCHUAN:MOVXA,DPTRMOVR0,ACLRAMOVXDPTR,AINCR0INCDPTRDJNZR7,CHUANSJMP$END8. 编程计算内部RAM 50H57H连续8个单元中所有数的算术平均值,将结果存放在5AH中。假设所有数据和不超过255。ORG0100HMOVR0,#50HMOVR1,#8CLRASUM:ADDA,R0INCR0DJNZR1,SUMMOVB,#8DIVABMOV5AH,ASJMP$END9. 设有100个有符号数,连续存放在以2000H为首地址的存储区中,试编程统计其中正数、负数、零的个数,并将其分别存入40H、41H和42H单元中。ORG0100HMOVDPTR,#2000HMOVR7,#100PD:MOVXA,DPTRJZZEROJNBACC.7,ZHENGINC41HLOOP:INCDPTRDJNZR7,PDSJMP$ZERO:INC42HSJMPLOOPZHENG:INC40HSJMPLOOPEND10. 编程设计发光二极管的闪烁程序。要求8只发光二极管每隔两只点亮一只,反复循环不止,变换时间为100ms,已知时钟频率为6MHZ。若时钟频率为6MHZ,则机器周期为2s,100ms延时子程序DELAY如下:DELAY:MOVR6,#100DEL:MOVR7,#250DJNZR7,$DJNZR6,DELRET发光二极管闪烁程序如下(设发光二极管为共阳极,低电平驱动,接P1口):ORG0100HMOVA,#0FEHLOOP:MOVP1,AACALLDELAYRLARLASJMPLOOPDELAY:(略)END11. 编程将外部RAM DATA1单元开始的50个字节数据逐一移至DATA2单元为起始地址的存储区中。ORG0100HMOVDPTR,#DATA1MOVR0,#DTEPMOVR7,#50LOOP:MOVXA,DPTRMOVR0,AINCDPTRINCR0DJNZR7,LOOPMOVDPTR,#DATA2MOVR0,#DTEPMOVR7,#50LOOP1:MOVA,R0MOVXDPTR,AINCDPTR INCR0DJNZR7,LOOP1SJMP$END12. 分别用数据传送指令和位操作指令编写程序,将内部RAM位寻址区128个位全部清零。(1)用数据传送指令MOVR0,#20HMOVR7,#10HCLRALOOP:MOVR0,AINCR0DJNZR7,LOOPSJMP$(2)用位操作指令CLR00HCLR01HCLR7FH13. 把长度为10H的字符串从内部RAM的输入缓冲区INBUF向位于外部RAM的输出缓冲区OUTBUF进行传送,当遇到字符“CR”或整个字符串传送完毕后停止传送。ORG0100HMOVR7,#10HMOVR0,#INBUFMOVDPTR,#OUTBUFLOOP:MOVA,R0CJNZA,#0D,JX;0DH为“CR”的ASCII码SJMPLENDJX:MOVXDPTR,AINCR0INCDPTRDJNZR7,LOOPLEND:SJMP$END14. 编写一个采用查表法求120的平方数子程序。要求:X在累加器中,1X20,平方数高位存放在R6,低位在R7中。ORG0100HMOVDPTR,#TABMOVR0,AADDA,R0MOVR7,AMOVCA,A+DPTRMOVR6,AMOVA,R7INCDPTRMOVCA,A+DPTRMOVR7,ASJMP$TAB:DW0,1,4,9,16,25,36,49,64,81,100,121,144,169,225DW256,289,324,361,400END15. 从内部RAM 30H单元开始,连续存有200字节的补码数,编写程序将它们改变为各自的绝对值。ORG0100HMOVR0,#30HMOVR7,#200LOOP:MOVA,R0JNBACC.7,ZHGSUBBA,#01HCPLAZHG:MOVR0,AINCR0DJNZR7,LOOPSJMP$END16. 若单片机的晶振频率为6MHZ,试编写一段延时子程序,其延时时间为500ms。若时钟频率为6MHZ,则机器周期为2s,500ms延时子程序DELAY如下:DELAY:MOVR6,#250DEL:MOVR7,#250DEL1:NOPNOPDJNZR7,DEL1DJNZR6,DELRET17. 在内部RAM STRING单元开始有一个字符串(字符串以00H结尾)。试编写一段程序,统计字符“$”的个数,并将结果存入NUM单元。ORG0100HMOVR0,#STRINGMOVNUM,#00HLOOP:MOVA,R0CJNEA,#24H,NEQ;24H为“$”的ASCII码INCNUMNEQ:INCR0CJNEA,#00H,LOOPSJMP$END第五章思考题与习题1. 名词解释:(1)中断 (2)中断源(3)中断系统(4)中断优先权(5)中断嵌套(6)中断屏蔽(1)中断是指在计算机执行程序过程中,由服务对象向CPU发出请求信号,要求CPU暂停当前程序的执行,而转去执行相应的处理程序,当待处理程序执行完后,再返回继续执行原来被中断程序的过程。(2)中断源是指引起中断的原因或触发中断请求的来源。(3)中断系统是指为实现中断而设置的各种硬件和软件。(4)中断优先权是指两个或两个以上中断源同时申请中断时,哪一个中断源被CPU优先响应的权力。(5)中断嵌套是指在一个中断处理还未完成时,优先级更高的中断打断了这个中断的执行过程,即一个中断程序中又有另一个中断在执行的情况。(6)中断屏蔽是指某中断被CPU禁止响应的情况。2. 89S51单片机中各中断源的中断处理程序的入口地址可否自行设定?当中断处理程序的长度大于8个字节时如何处理?89S51单片机中各中断源的中断处理程序的入口地址不能自行设定,当中断处理程序的长度大于8个字节时,应设置一条无条件跳转指令,将中断处理程序写入其他存储区。3. 89S51单片机的中断系统由哪些部件构成?分别有何用处?89S51单片机的中断系统由中断源、中断标志位、中断允许控制寄存器、中断优先级控制寄存器及中断入口地址组成。中断源用于产生中断请求信号;中断标志位用于将中断源产生的中断请求做上标记,以便于CPU能及时查询到中断的请求;中断允许控制寄存器用于设置哪些中断源可以被CPU响应,哪些被禁止;中断优先级控制寄存器的作用是设置各种中断源的优先顺序;中断入口地址用于将中断处理程序的首地址存入PC指针以控制中断服务程序的执行。4. 89S51单片机中断系统有几个中断源?各中断标志如何产生?如何清除?CPU响应中断时,它们的中断入口地址分别是多少?89S51单片机中断系统有五个中断源,是通过TCON、SCON中的IE0、IE1、TF0、TF1、TI、RI六个标志位产生的。其中,IE0、IE1、TF0、TF1由硬件清零,TI、RI由软件清零。它们的中断入口地址分别是0003H(外部中断0)、0013H(外部中断1)、000BH(定时器0)、001BH(定时器1)、0023H(串行口)。5. 89S51内部设有几个定时器/计数器?它们是由哪些特殊功能寄存器组成的?89S51内部设有2个定时器/计数器,它们是由TCON、TMOD、TH1、TH0、TL1、TL0组成。6. 89S51单片机定时/计数器T0、T1有哪几种操作模式?它们有什么区别?89S51单片机定时/计数器T0、T1有4种操作模式。方式0为13位定时/计数器,方式1为16位定时/计数器,方式2为自动重装初值的8位定时/计数器,方式3为T0被拆成两个独立的8位定时/计数器。7. 89S51单片机定时/计数器在定时或计数工作方式下,其计数脉冲分别由谁提供?定时时间与哪些因素有关?做计数时,对外界计数脉冲频率有何限制?89S51单片机定时/计数器在定时工作方式下,其计数脉冲由内部机器周期提供;89S51单片机定时/计数器在计数工作方式下,其计数脉冲由外部引脚T0(P3.4)、T1(P3.5)提供。定时时间与定时器工作方式及单片机时钟有关。做计数时,对外界计数脉冲频率必需小于时钟频率的1/24,且高低电平持续时间不得小于一个机器周期。8. 设单片机的fosc=12MHz,若内部RAM的30H单元的内容为55H,则定时器的定时时间为30ms;否则定时时间为15ms。试对定时/计数器进行初始化编程。MOVTMOD,#01HMOVTH0,#0C5HMOVTL0,#68HMOVA,30HCJNEA,#55H,STMOVTH0,#8AHMOVTL0,#0CFHST:9. 已知89S51的fosc=6MHz,利用定时/计数器T0编程实现P1.0端口输出矩形波。要求:矩形波高电平宽度为50s,低电平宽度为300s。将T0作为定时器,工作在方式2,定时时间为25s,则初值为256-25=231=E7H,TMOD=00000010B=02H。ORG0000HLJMPSTARTORG000BHLJMPINTT0ORG0050HSTART:CLRP1.0MOVTMOD,#02HMOVTH0,#0E7HMOVTL0,#0E7HSETBPT0MOVIE,#10000010BSETBTR0SETBP1.0SETBF0MOVR7,#6LJMP$ORG0100HINTT0:JBF0,GAODJNZR7,IEDMOVR7,#6GAO:CPLP1.0CPLF0IED:RETIEND10. 已知 89S51的fosc=12MHz,用定时/计数器T1编程实现P1.0和 P1.1引脚上分别输出周期为2ms和500s的方波。将T1作为定时器,工作在方式2,定时时间为250s,则初值为256-250=6=06H,TMOD=00100000B=20H。ORG0000HLJMPSTARTORG001BHLJMPINTT1ORG0050HSTART:CLRP1.0CLRP1.1MOVTMOD,#20HMOVTH1,#06HMOVTL1,#06HSETBPT1MOVIE,#10001000BSETBTR1MOVR7,#4LJMP$ORG0100HINTT1:CPLP1.1DJNZR7,IEDMOVR7,#4CPLP1.0IED:RETIEND11. 什么是串行异步通信?它有哪些特点?串行异步通信是指数据传送时各位分时传送,只需要一根数据线。在传送过程中数据以字符为单位传送,每个字符数据都要加进一些识别信息位和校验位,数据发送和接收端的时钟可以不同步。它的特点是节省传输线路,可实现远距离通信,传输速度相对同步通信慢,异步通信不需要发送端和接收端的时钟严格同步。12. 89S51单片机的串行口由哪些功能部件组成?各有何作用?89S51单片机的串行口由SCON、SBUF及若干门电路构成。SCON用于设置串行口的工作方式,SBUF用于存储串行通信时要发送的数据或已接收到的数据。13. 89S51的串行数据缓冲器只有一个地址,如何判断是发送还是接收信号?通过不同的传送指令进行区分,如果发送数据则使用“MOVSBUF,A”,如果接收数据则使用“MOVA,SBUF”14. 89S51的串行口有几种工作方式?各种方式下的数据格式及波特率有何区别?89S51的串行口有4种工作方式。方式0为同步移位寄存器方式,波特率为fOSC/12;方式1为10位异步通信方式,波特率可调;方式2为11位异步通信方式,波特率为fOSC/32或fOSC/64;方式3为11位异步通信方式,波特率可调。15. 试用查询方式编写一数据块发送程序。数据块首址为内部RAM的30H单元,其长度为20个字节,设串行口工作于方式1,传送的波特率为9600bps(fosc=6MHz),不进行奇偶校验处理。设波特率=9600bps。由T1工作于方式2,fosc=6MHz,SMOD=1,求得TH1=TL1=0FDH。ORG0100HFIRST:MOVTMOD,#20HMOVTH1,#0FDHMOVTL1,#0FDHMOVSCON,#40HMOVPCON,#80HSETBTR1MOVR0,#30HMOVR1,#20F:MOVA,R0MOVSBUF,AJF:JBCTI,GGSJMPJFGG:INCR0 DJNZR1,FSJMP$END16. 试用中断方式编写一数据块接收程序。接收缓冲区首址为内部RAM的20H单元,接收的数据为ASCII码,设串行口工作于方式1,波特率设定为1200bps(fosc=11.0592MHz),接收时进行奇偶校验,若出错则删除接收的数据。设波特率=1200bps。由T1工作于方式2,fosc=11.0592MHz,SMOD=0,求得TH1=TL1=0E8H。ORG 0000H LJMP MAINR;转接收主程序 ORG 0023H LJMP INTSE2;转中断服务程序 MAINR:MOV SP,#60H;主程序MOVTMOD,#20HMOVTH1,#0E8HMOVTL1,#0E8HMOV SCON,#50H;串行口初始化,允许接收MOV PCON,#00H SETB EA;开中断 SETB ESSETBTR1 MOV R1,#20H;置接收缓冲区首址 SJMP $ INTSE2:CLR RI;清中断标志MOV A,SBUF;接收数据JNBPSW.0,RX1;P=0,转RX1JNBRB8,RERR;P=1,RB8=0,转出错处理SJMPRX2RX1:JBRB8,RERR;P=0,RB8=1,转出错处理RX2:MOVR1,A ;保存数据INCR1RETIRERR:CLRASJMPRX2END第六章思考题与习题1. 在89S51扩展系统中,程序存储器和数据存储器共用了16位地址线和8位数据线,为什么两个存储空间不会发生冲突?两个存储器读写方式不同,读信号接线方式也不同,因此不会发生冲突。2. 为什么当P2作为扩展存储器的高8位地址后,不再适用作I/O口?因为P2被用作高8位地址输出时,若再作I/O口会使数据被修改,则使输出的地址也被修改,此时单片机外部所接存储器地址也会被修改,导致读写数据错误。3. 请用译码器74LS138设计一个译码电路,分别选中4片2864,且列出各芯片所占的地址空间范围。2864的存储容量为8K,每片芯片地址范围0000H1FFFH,使用74LS138扩展图如下。则四片2864的地址范围依次是(1)0000H1FFFH,(2)2000H3FFFH,(3)4000H5FFFH,(4)6000H7FFFH。4. 试说明8155的内部结构特点,其定时/计数器与89S51内部的定时/计数器有何异同?8155芯片内部包含2个8位I/O并行接口和1个6位I/O并行接口,一个14位的减1定时/计数器及256字节片内RAM。其定时/计数器是14位减计数,而89S51内部的定时/计数器是16位加计数。5. 说明8155工作方式控制字的作用及各位的功能。D7D6D5D4D3D2D1D0TM2TM1IEBIEAPC2PC1PBPAPB、PA:控制端口B与A的数据传送方式。PC2、PC1:控制端口工作方式。TM2、TM1:控制定时/计数器工作方式。IEB、IEA:控制端口B与A的中断。6. 试对8155进行初始化编程,使其A口作输出口,B口作输入口,并启动定时/计数器,输出连续方波,定时时间为10毫秒,输入时钟频率为500kHz。计数初值=5000=1388HORG0100H START:MOV DPTR,#7F00H;DPTR指向命令寄存器地址MOV A,#01H ;命令字00000001BMOVXDPTR,A ;初始化8155MOVDPTR,#7F04H;送低8位计数值MOVA,#88HMOVXDPTR,A INC DPTR ;送高6位计数值 MOVA,#53H ;设置M2M1=01,输出脉冲为连续方波 MOVXDPTR,A MOV DPTR,#7F00H;启动计数器工作MOV A,#0C0H;设置工作方式控制字 MOVXDPTR,A7. 用串行口扩展4个LED数码管显示电路,编程使数码管轮流显示“ABCD”,“EFGH”,每秒钟变换一次。ORG0100HSTART:MOVDPTR,#TABMOVR0,#50HMOVR7,#4ABCD:CLRAMOVCA,A+DPTR;查显示码MOVR0,AINCDPTRINCR0DJNZR7,ABCDACALLDISPACALLDELAYMOVR0,#50H MOVR7,#4EFGH:CLRAMOVCA,A+DPTR;查显示码MOVR0,AINCDPTRINCR0DJNZR7,EFGHACALLDISPACALLDELAYLJMPSTARTDISP:CLRP1.4;显示器熄灭SETBP1.3;打开移位脉冲输入SETBP1.4;打开74LS164MOVSCON,#00H;设置串口工作在方式0MOVR0,#50H;设置显示缓冲区首址MOVR2,#04H;设置循环次数LOOP: MOVA,R0MOVSBUF,A;送显示WAIT:JNBTI,WAIT;发送是否完成CLRTI;清发送完成标志INCR0DJNZR2,LOOP;未发送完继续CLRP1.3RETDELAY:MOVR6,#10DLY1:MOVR5,#200DLY2:MOVR4,#250DLY3:DJNZR4,DLY3DJNZR5,DLY2DJNZR6,DLY1RETTAB:DB88H,83H,0A7H,0A1H,84H,8EH,90H,89HEND8. 试说明键盘的工作原理,并说明键盘消抖的作用。如图6-10所示,键盘的工作原理简单的说就是当任意一个按键被按下,都会使相应的端子出现低电平。若没有按键按下,则为高电平。通过单片机检测输入端子的状态就可以判断键盘的按键是否按下。键盘消抖的作用为了保证按键识别的准确性。9. 在一个晶振为12MHZ的89S51应用系统中,接有一片DAC0832,它的地址为7FFFH,输出电压为05V。试编写一个程序,使DAC0832输出一个矩形波,波形占空比为1:4。高电平时电压为2.5V,低电平时电压为1.25V。ORG0100HSTART:MOVDPTR,#7FFFH;送DAC0832的地址MOVA,#80H;装入待转换的数据LOOP:MOVXDPTR,A;启动A/D转换ACALL DELAYMOVA,#40HACALL DELAYACALL DELAYACALL DELAYAJMPSTARTDELAY:(略)10. 在一个晶振为12MHz的89S51应用系统中,接有一片A/D器件ADC0809,它的地址为0EFF8H0EFFFH。试编写定时采样03通道的程序。设采样的周期为2ms/次,每个通道采样50个数。把所采样的数按0、1、2、3通道的顺序存放在以3000H为首址的片外数据存储区中。设定时器T0工作在方式1,定时时间为2ms,则定时器的初值为TH0=F8H,TL0=30H。ORG0000HLJMPMAINORG000BHLJMPT0INTMAIN:MOVSP,#60HMOVR0,#30HMOVR1,#00HMOVR7,#00HMOVTMOD,#01HMOVTH0,#0F8HMOVTL0,#30HMOVIE,#82HSETBTR0MOVDPTR,#0EFF8H;选通IN0LJMP$ T0INT:PUSHDPHPUSHDPLMOVXDPTR,A;启动A/D转换JNBEOC,$MOVXA,DPTR;取A/D转换结果INCR7MOVDPH,R0MOVDPL,R1MOVDPTR,A;存结果INCDPTRMOVR0,DPH MOVR1,DPLCJNER7,#50,NEXT;未转换完50次,继续转换MOVR7,#00HPOPDPLINCDPLMOVA,DPLCJNEA,#0FCH,NEXT1CLRTR0SJMPNEXT1NEXT:POPDPLNEXT1:POPDPHRETI;中断返回第七章思考题与习题1. 单片机应用系统设计有哪些基本要求?(1)可靠性要高(2)操作维修要方便(3)性能价格比要高(4)具有自我保护意识2. 单片机应用系统有哪些部分组成?单片机应用系统由硬件和软件两大部分组成。硬件由单片机、存储器、若干I/O接口及外围设备等组成;软件主要有实时软件和开发软件两大类构成。3. 单片机选型应考虑哪几个方面?(1)单片机的系统适应性(2)单片机的可开发性(3)制造商历史及可购买性4. 说明抑制单片机系统供电干扰的主要方法。(1)单片机输入电源与强电设备动力电源分开。(2)采用具有静电屏蔽和抗电磁干扰的隔离电源变压器。(3)交流进线端加低通滤波器,可滤掉高频干扰。安装时外壳要加屏蔽并使其良好接地,滤波器的输入、输出引线必须相互隔离,以防止感应和辐射耦合。直流输出部分采用大容量电解电容进行平滑滤波。(4)对于功率不大的小型或微型计算机系统,为了抑制电网电压起伏的影响,可设置交流稳压器。(5)采用独立功能块单独供电,并用集成稳压块实现两级稳压。(6)尽量提高接口器件的电源电压,提高接口的抗干扰能力。5. 自行设计软件“看门狗”程序。(略)第八章思考题与习题1. 设计一个8路模拟信号数值显示电路。要求:可自动轮流显示8路模拟信号的数值,最小分辨率为0.02V,模拟量输入最大值为5V,最大显示值为255(输入为5V时)。(略)2. 设计一个自行车里程/速度计。要求:能自动显示自行车骑行的总里程数及骑行速度,具有超速报警功能。(略)3. 设计一个电子秤。要求:能称50公斤货物,最小分辨率为0.01公斤。(略)第九章思考题与习题1. 定义变量a、b、c,a为内部RAM的可位寻址区的字符变量,b为外部数据存储区的整型变量,c为指向整型xdata区的指针。char bdata aint xdata bint xdata *c2. 编程将89S51单片机内部数据存储器20H单元和35H单元的数据相乘,结果存入外部数据存储器中。void main(void)char data *a; char data *b;char xdata *c;a=0x20;b=0x35;c=0x2000;*c=*a*b;3. 编程将外部RAM 10H15H单元的内容传送到内部RAM 10H
展开阅读全文
相关资源
相关搜索

最新文档


当前位置:首页 > 办公文档


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!