文档介绍:该【单片机原理及应用教程第版习题课后答案 】是由【1781111****】上传分享,文档一共【44】页,该文档可以免费在线阅读,需要了解更多关于【单片机原理及应用教程第版习题课后答案 】的内容,可以使用淘豆网的站内搜索功能,选择自己适合的文档,以下文字是截取该文章内的部分文字,如需要获得完整电子版,请下载此文档到您的设备,方便您编辑和打印。:..(第三版),由于所采用的电子逻辑器件仅能存储和识别两种状态的特点,计算机内部一切信息存储、处理和传送均采用二进制数的形式。可以说,二进制数是计算机硬件能直接识别并进行处理的惟一形式。十六进制数可以简化表示二进制数。2.(1)0111100179H(2)(3)(4).101(5)0110000161H(6)0011000131H3.(1)0B3H(2)80H(3)(4)4.(1)01000001B65(2)1B4315.(1)0010010000100**********(2)(5)。一般情况下,可分为系统总线和外总线。系统总线应包括:地址总线(AB)控制总线(CB)数据总线(DB)地址总线(AB):CPU根据指令的功能需要访问某一存储器单元或外部设备时,其地址:..位时,可寻址范围为216=64K,地址总线的位数决定了所寻址存储器容量或外设数量的范围。在任一时刻,地址总线上的地址信息是惟一对应某一存储单元或外部设备。控制总线(CB):由CPU产生的控制信号是通过控制总线向存储器或外部设备发出控制命令的,以使在传送信息时协调一致的工作。CPU还可以接收由外部设备发来的中断请求信号和状态信号,所以控制总线可以是输入、输出或双向的。数据总线(DB):CPU是通过数据总线与存储单元或外部设备交换数据信息的,故数据总线应为双向总线。在CPU进行读操作时,存储单元或外设的数据信息通过数据总线传送给CPU;在CPU进行写操作时,、输出设备交换信息,一般情况下,外部设备种类、数量较多,而且各种参量(如运行速度、数据格式及物理量)也不尽相同。CPU为了实现选取目标外部设备并与其交换信息,必须借助接口电路。一般情况下,接口电路通过地址总线、控制总线和数据总线与CPU连接;通过数据线(D)、控制线(C)和状态线(S)与外部设备连接。,用来存放数据和程序。计算机中的存储器主要有随机存储器(RAM)和只读存储器(ROM)两种。随机存储器一般用来存放程序运行过程中的中间数据,计算机掉电时数据不再保存。只读存储器一般用来存放程序,计算机掉电时信息不会丢失。,它表示多少个存储单元64×。:..什么是单片机单片机与微机相比有何特点单片机(Single-Chip-puter)又称单片微控制器,其基本结构是将微型计算机的基本功能部件:中央处理机(CPU)、存储器、输入接口、输出接口、定时器/计数器、中断系统等全部集成在一个半导体芯片上,因此,单片机其体积小、功耗低、价格低廉,且具有逻辑判断、定时计数、程序控制等多种功能。单片机结构上的设计,在硬件、指令系统及I/O能力等方面都有独到之处,具有较强而有效的控制功能。虽然单片机只是一个芯片,但无论从组成还是从其逻辑功能上来看,都具有微机系统的含义。另一方面,单片机毕竟是一个芯片,只有外加所需的输入、输出设备,才可以构成实用的单片机应用系统。(1)智能仪器。智能仪器是含有微处理器的测量仪器。单片机广泛应用于各种仪器仪表,使仪器仪表智能化取得了令人瞩目的进展。(2)工业控制。单片机广泛应用于各种工业控制系统中,如数控机床、温度控制、可编程顺序控制等。(3)家用电器。目前各种家用电器普遍采用单片机取代传统的控制电路,如洗衣机、电冰箱、空调、彩电、微波炉、电风扇及高级电子玩具等。由于配上了单片机,使其功能增强而身价倍增,深受用户的欢迎。(4)机电一体化。机电一体化是***发展的方向,机电一体化产品是指集机械技术、微电子技术、计算机技术于一体,具有智能化特征的机电产品。单片机除以上各方面应用之外,还广泛应用于办公自动化领域(如复印机)、汽车电路、通信系统(如手机)、计算机外围设备等,成为计算机发展和应用的一个重要方向。:..以应用为中心、以计算机技术为基础、软件硬件可裁减、功能、可靠性、成本、体积、功耗严格要求的专用计算机系统”。即以嵌入式应用为目的计算机系统。嵌入式系统的重要特征:(1)系统内核小(2)专用性强。(3)系统精简嵌入式系统一般没有系统软件和应用软件的明显区分,其功能设计及实现上不要求过于复杂,这样一方面利于控制系统成本,同时也利于实现系统安全。(4)高实时性。-51有哪些典型产品,它们有何区别MCS-51系列单片机可分为两大系列:51子系列和52子系列。51子系列单片机的典型产品有8051、8751、8031、80C51、80C31等。它们的结构基本相同,、4KB的ROM、128B的RAM、4个8位的I/O并行端口、一个串行口、两个16位定时/计数器及中断系统等组成。,用于寄存当前指令执行后的某些状态,即反映指令执行结果的一些特征信息。Cy():即PSW的D7位,进位/借位标志。AC():即PSW的D6位,辅助进位标志。F0()及F1():即PSW的D5位、D1位,用户标志位。RS1及RS0(及):即PSW的D4位、D3位,寄存器组选择控制位。:..:即PSW的D2位,溢出标志。-51存储器结构的主要特点是什么程序存储器和数据存储器各有何不同MCS-51单片机的存储器结构与一般微机存储器的配置方法不同,一般微机把程序和数据共存同一存储空间,各存储单元对应惟一的地址。而MCS-51的存储器把程序和数据的存储空间严格区分开。数据存储器用于存放程序运算的中间结果、状态标志位等。程序存储器用于存放已编制好的程序及程序中用到的常数。-51单片机内部RAM可分为几个区各区的主要作用是什么内部数据存储器分为高、低128B两大部分。低128B为RAM区,地址空间为00H~7FH,可分为:寄存器区、位寻址区、堆栈及数据存储区。存放程序运算的中间结果、状态标志位等。高128B为特殊功能寄存器(SFR)区,地址空间为80H~FFH,其中仅有21个字节单元是有定义的。-51单片机的P0~P3四个I/O端口在结构上有何异同使用时应注意哪些事项P0口是一个8位漏极开路型双向I/O端口。P1口是一个内部带上拉电阻的8位准双向I/O端口。P2口也是一个内部带上拉电阻的8位准双向I/O端口P3口是一个内部带上拉电阻的8位多功能双向I/O端口。在使用时应注意以下方面:①P0~P3都是准双向I/O口,即CPU在读取数据时,必须先向相应端口的锁存器写入“1”。各端口名称与锁存器名称在编程时相同,均可用P0~P3表示。当系统复位时,P0~P3端口锁存器全为“1”,故可直接对其进行读取数据。②P0口每一输出位可驱动8个LS型TTL负载,P0口可作通用输入、输出端口使用,:..或其他拉电流负载时,需外接上拉电阻,才能使该位高电平输出有效。在单片机进行外部存储器扩展时,P0口必须作为地址/数据复用线使用,此时,不必外接上拉电阻,P0也不能作通用I/O口使用。③P1、P2、P3口输出均接有内部上拉电阻,输入端无需外接上拉电阻,每一位输出可以驱动4个LS型TTL电路。④P0、P2口除可以作通用I/O端口、以实现与外部进行数据交换外,更主要的是,当CPU访问外部存储器时,CPU将自动地把外部存储器的地址线信号(16位)送P0、P2口,作为地址总线(P0口输出低8位地址,P2口输出高8位地址),向外部存储器输出16位存储单元地址。在控制信号作用下,该地址低8位被锁存后,P0口自动切换为数据总线,这时经P0口可向外部存储器进行读、写数据操作。此时,P2口不再作通用I/O端口,P0口为地址/数据复用口。,P3口作为第二功能使用P3口的第二功能是作为控制端口使用的。由于单片机没有专设的控制信号引脚,单片机在进行外部存储器和I/O端口扩展时所需要的控制信号必须由P3口提供,P3口第二功能相当于PC机中CPU的控制线引脚。,开关量控制是控制系统的主要对象之一。作为传统的CPU,对于简单的个别开关量进行控制却显得不那么方便,而让MCS-51值得骄傲的正是它有效地解决了单一位的控制。MCS-51片内CPU还是一个性能优异的位处理器,也就是说MCS-51实际上又是一个完整而独立的1位单片机(也称布尔处理机)。该布尔处理机除了有自己的CPU、位寄存器、位累加器(即进位标志Cy)、I/O口和位寻址空间外,还有专供位操作的指令系统,:..的某一位进行操作。MCS-51单片机对于位操作(布尔处理)有置位、复位、取反、测试转移、传送、逻辑与和逻辑或运算等功能。所以,单片机具有较强的位处理能力。。00~7FH(即~及SFR地址能被8整除的寄存器中的各位。,P0和P2口各用来传送什么信号P0口为什么要采用片外地址锁存器P0口传送地址低八位后可复用数据线,所以,P0口要采用片外地址锁存器。P2口传送地址高八位。,一个机器周期为多少微秒时钟周期:也称振荡周期,即振荡器的振荡频率f的倒数,是时序中最小的时间单位。osc机器周期:执行一条指令的过程可分为若干个阶段,每一阶段完成一规定的操作,完成一个规定操作所需要的时间称为一个机器周期,一个机器周期包含12个时钟周期。当振荡频率为12MHz时,一个机器周期为12/(12×1000000)秒=1微秒指令周期:定义为执行一条指令所用的时间。-51单片机有几种复位方法复位后,CPU从程序存储器的哪一个单元开始执行程序MCS-51的复位电路包括上电复位电路和按键(外部)复位电路0000H:..RAM中的数据单片机在运行过程中,如果发生掉电,片内RAM和SFR中的信息将会丢失。为防止信息丢失,可以把一组备用电源加到RST/V端,当V上的电压低于V上的电压时,PD备用电源通过V端,以低功耗保持内部RAM和SFR中的数据。,ALE上输出的脉冲频率是多少其作用是什么地址锁存使能输出ALE:当单片机访问外部存储器时,外部存储器的16位地址信号由P0口输出低8位,P2口输出高8位,ALE可用作低8位地址锁存控制信号;当不用作外部存储器地址锁存控制信号时,该引脚仍以时钟振荡频率的1/6固定地输出正脉冲,可以驱动8个LS型TTL负载。-51有哪几种寻址方式举例说明它们是怎样寻址的MCS-51指令系统的寻址方式有以下7种:立即寻址方式:操作数直接出现在指令中。直接寻址方式中:操作数的单元地址直接出现在指令中。寄存器寻址方式中:寄存器中的内容就是操作数。寄存器间接寻址方式中,指定寄存器中的内容是操作数的地址,该地址对应存储单元的内容才是操作数。变址寻址方式是以程序指针PC或数据指针DPTR为基址寄存器,以累加器A作为变址寄存器,两者内容相加(即基地址+偏移量)形成16位的操作数地址,相对寻址是以程序计数器PC的当前值作为基地址,与指令中的第二字节给出的相对偏移量rel进行相加,所得和为程序的转移地址。位地址:内部RAM地址空间的可进行位寻址的128位和SFR地址空间的可位寻址的11个8位寄存器的88位。位寻址给出的是直接地址。:..由寻址方式可以看出,不同的寻址方式所寻址的存储空间是不同的。正确地使用寻址方式不仅取决于寻址方式的形式,而且取决于寻址方式所对应的存储空间。字节寻址必须是对8位存储单元,位寻址的存储空间只能是片内RAM的20H~2FH字节地址中的所有位(位地址为00H~7FH)和部分SFR的位,决不能是该范围之外的任何单元的任何位。,应采用什么寻址方式举例说明。访问专用寄存器:可采用直接寻址或寄存器寻址。访问片外数据寄存器:,若需要保护现场数据(如内部RAM单元的内容),可使用入栈指令,将数据压入堆栈,中断处理过程执行完后,再使用出栈指令恢复现场数据。。MOVA,20HMOVDPTR,#******@DPTR,~30H单元内容清零。MOVR0,#20HMOVA,#0MOVR3,#17LOP:******@R0,AINCR0:..7RAM的32H~41H单元中是否有0AAH这个数据,若有这一数据,则将50H单元置为0FFH,否则清50H单元为0。MOVR3,#10HMOVA,#0AAHMOVR0,#31HLOP:INCR0SUBBA,***@R0JZLOP1DJNZR3,LOPMOV50H,#0HAJMPLOP3LOP1:MOV50H,#0FFHLOP3:~4FH单元中出现00H的次数,并将查找结果存入50H单元。MOVR3,#30HMOVR0,#20HMOVA,#0LOP:MOVA,***@R0JZLOP1LOP3:INCR0:..DJNZR3,LOPAJMPLOP2LOP1:INC50HAJMPLOP3LOP2:AJMPLOP29A=83H,R0=17H,(17H)=34H,写出下列程序段执行完后的A中的内容。ANLA,#17HORL17H,AXRLA,***@R0CPLA(A)=B==12MHz,分别设计延时、1s、1min的子程序。osc设晶振频率为12MHz,一个机器周期为1,延时1ms的子程序:执行时间(机器周期)DELAY:MOVR7,#0FFH1LOOP:NOP1NOP1DJNZR7,LOOP2RET2该程序段的总的执行时间为:(1+4×255+2)s=1023μs≈1ms延时时间为100ms的子程序:DELAY:MOVR5,#64H对延时1ms的子程序循环100次。LOP1:MOVR7,#0FFHLOOP:NOPNOPDJNZR7,LOOPDJNZR5,LOP1RET:..1s的子程序:DELAY1:MOVR3,#0AH对延时100ms的子程序循环10次DELAY:MOVR5,#64H。LOP1:MOVR7,#0FFHLOOP:NOPNOPDJNZR7,LOOPDJNZR5,LOP1DJNZR3,DELAYRET延时时间为60s的子程序:-51汇编语言中有哪些常用的伪指令各起什么作用BIT(地址符号命令)END(结束汇编)EQU(等值)DB(定义字节)DW(定义字)DS(定义存储单元)ORG(汇编起始地址)①MOVA,R1;MOV0E0H,R1指令功能相同,寻址方式表示不同:..②MOVA,P0;MOVA,80H指令功能相同,寻址方式表示不同③LOOP:SJMPLOOP;SJMP$,从3000H开始各有关存储单元的内容是什么ORG3000HTAB1:EQU1234HTAB2:EQU5678HDBDWTAB1,TAB2,9ABCH3000H:653001H:133002H:a’3003H:‘b’3004H:‘c’3005H:‘A’3006H:’B’3007H:‘C’3008H:34H3009H:12H300AH:78H300BH:56H300CH:0BCH300DH:,在编写时应注意哪些问题(1)把要解决的问题化成一个个具有一定独立性的功能模块,各模块尽量采用子程序完成其功能。:..力求少用无条件转移指令,尽量采用循环结构。(3)对主要的程序段要下功夫精心设计,这样会收到事半功倍的效果。(4)能用8位数据解决问题的就不要使用16位数据。(5)累加器是信息传递的枢纽,在调用子程序时应通过累加器传送子程序的参数,通过累加器向主程序传送返回参数。所以,在子程序中一般不把累加器推入堆栈。若需保护累加器的内容时,应先把累加器的内容存入其他寄存器单元,然后再调用子程序。(6)为了保证程序运行的安全可靠,应考虑使用软件抗干扰技术,如数字滤波技术、指令冗余技术、软件陷井技术,用汇编语言程序实现这些技术,不需要增加硬件成本,可靠性高,稳定性好,方便灵活。,外部数据存储器地址范围为40H~47H,内部数据存储器地址范围为30H~37H。MOVR3,#8MOVR0,#40HMOVR1,#30HLOP1:MOVXA,***@******@R1,AINCR0INCR1DJNZR3,,外部程序存储器地址为2040H~2047H,内部RAM地址为30H~37H。:..题答案(提示:外部程序存储器地址为16位地址:2040H~2047H,间接寻址采用DPTR)~4FH单元的数据块按降序排列。参看23题答案(提示:本题对20H~4FH单元(48个)数据降序排列)。,以0DH为结束标志,试统计该数据块长度,将该数据块传送到外部数据存储器7E01H开始的单元,并将长度存入7E00H单元。MOVR0,#20HMOVDPTR,#7E01HLOP:MOVA,***@R0MOV60H,ASUBBA,#0DHJZLOP1MOVA,******@DPTR,AINCR3INCR0INCDPTRAJMPLOPLOP1:MOVDPTR,#7E00HMOVA,******@DPTR,AEND:..190~9字形7段码(假设表的首地址为TABLE)的子程序,调用子程序前,待查表的数据存放在累加器A中,子程序返回后,查表的结果也存放在累加器A中。SQR1:MOVDPTR,#TABLEMOVCA,***@A+DPTRRETTABLE:DB0C0H,0F9H,0A4H,0B0H,99H;0~9的字形显示段码(LED共阳极。DB92H,82H,F8H,80H,,求其累加和,并将结果存入SUM和SUM+1单元。MOVR0,#DATAMOVR3,#0AHMOVA,#0LOP:ADDA,***@R0MOVR4,AADDCA,#0MOVR5,AINCR0DJNZR3,LOPMOVSUM,R4MOVSUM+1,R5:..END21RAM的DATA1和DATA2单元开始存放着两个等长的数据块,数据块的长度在LEN单元中。请编程检查这两个数据块是否相等,若相等,将0FFH写入RESULT单元,否则将0写入RESULT单元。MOVR0,#DATA1MOVR3,LENLOP:MOVA,***@R0CJNZA,DATA2,LOP1INCR0INCDATA2DJNZR3,LOPMOVA,#0FFHMOVRESULT,AAJMPLOP2LOP1:MOVA,#0MOVRESULT,ALOP2:,其端口地址为20H,要求在1秒钟时间内连续采样10次读取该端口数据,求其算术平均值,结果存放在内部RAM区20H单元。MOVR0,#20HMOVR2,#0:..MOVA,#0MOVR4,#0LOP:MOVR3,#0AHIN:ACALLDELAYMOVXA,***@R0MOVR2,AMOVA,R4ADDA,R2MOVR4,ADJNZR3,INMOVB,#0AHDIVABMOV20H,AAJMPLOPDELAY:MOVR5,#64HLOP1:MOVR7,#0FFHLOOP:NOPNOPDJNZR7,LOOPDJNZR5,,将内部RAM区以30H为起始地址的连续10个存储单元中的数据,:..采用冒泡法排序:冒泡排序法的基本算法是:N个数排序,从数据存放单元的一端(如起始单元)开始,将相邻二个数依次进行比较,如果相邻两个数的大小次序和排序要求一致,则不改变它们的存放次序,否则相互交换两数位置,使其符合排序要求,这样逐次比较,直至将最小(降序)或最大(升序)的数移至最后。然后,再将n-1个数继续比较,重复上面操作,直至比较完毕。可采用双重循环实现冒泡法排序,外循环控制进行比较的次数,内循环实现依次比较交换数据。程序如下:ORG0000HBLOCKEQU30H;设BLOCK为30H单元MOVR7,#9H;设置外循环计数器NEXT:MOVA,R7MOV80H,AMOVR6,A;设置外循环计数器MOVR0,#30H;设置数据指针COMP:MOVA,***@R0MOVR2,AINCR0CLRCSUBBA,***@R0JCLESSMOVA,R2XCHA,***@******@R0,AINCR0LESS:P;(R6)-1不等于0,转COMP继续内循环MOVR0,#30HDEC80HMOVR6,-51系列单片机能提供几个中断源、几个中断优先级各个中断源的优先级怎样:..答:MCS-51系列单片机能提供5个中断源,2个中断优先级。各个中断源的优先级是由特殊功能寄存器IP来确定,IP中和各个中断源对应位为1时,此中断源为高优先级,否则为低优先级。在同一优先级中,各个中断源的优先顺序是由自然优先级来确定的。-51系列单片机的中断响应过程。答:MCS-51系列单片机的中断响应过程是按照以下顺序执行的:开中断-----中断请求------中断判断-------中断响应-------中断返回。-51系列单片机的外部中断有哪两种触发方式如何设置对外部中断源的中断请求信号有何要求答:MCS-51系列单片机的外部中断有电平触发和边沿触发两种方式。是由特殊功能寄存器TCON中IT0,IT1的状态确定的,如:IT0为1时外部中断0为边沿触发方式,当INT0外部引脚出现下降沿时向CPU提出中断请求,否则为电平触发方式,当INT0外部引脚出现低电平时向CPU提出中断请求。-51单片机中断响应时间是否固定为什么答:MCS-51单片机中断响应时间不固定,因为当中断源向CPU提出中断请求时,CPU正在执行的指令的指令周期是不一样的。-51单片机如果扩展6个中断源,可采用哪些方法如何确定它们的优先级答:一般可采取中断加查询方式,软件先查询到的为高优先级,最后查询到的为低优先级。,如果有新的中断请求出现,问在什么情况下可响应新的中断请求在什么情况下不能响应新的中断请求答:当正在执行某一中断源的中断服务程序时,如果有新的中断请求出现,当新中断源中断级别比正在执行中断源的中断级别高时可响应新的中断请求,否则不能响应新的中断请求。:..8051单片机有5个中断源,但只能设置两个中断优先级,因此,在中断优先级安排上受到一定的限制。问以下几种中断优先级顺序的安排(级别由高到低)是否可能如可能,则应如何设置中断源的中断级别否则,请叙述不可能的理由。(1)定时器0,定时器1,外中断0,外中断1,串行口中断。可能。其中:定时器0,定时器1为高优先级。(2)串行口中断,外中断0,定时器0,外中断1,定时器1。可能。其中:串行口中断为高优先级。(3)外中断0,定时器1,外中断1,定时器0,串行口中断。不可能。(4)外中断0,外中断1,串行口中断,定时器0,定时器1。可能。其中:外中断0,外中断1,串行口中断为高优先级。(5)串行口中断,定时器0,外中断0,外中断1,定时器1。不可能。(6)外中断0,外中断1,定时器0,串行口中断,定时器1。不可能。(7)外中断0,定时器1,定时器0,外中断1,串行口中断。可能。其中:外中断0,定时器1为高优先级。:8051定时器/计数器有0,1,2,3四种工作模式。模式0为13位1定时器/计数器,模式1为16位1定时器/计数器,模式2为自动赋初值的8位定时器/计数器,模式3:..位定时器(T1没有模式3)。,其计数脉冲分别由谁提供答:8051定时器作定时器时,输入的记数脉冲是由晶体振荡器的输出经12分频后得到的,所以定时器可看作是对单片机机器周期的计数器。8051定时器作计数器时,则对外部事件进行计数。,定时器如何启动答:8051定时器的门控信号GATE为1时,只有INT0(或INT1)引脚为高电平且TR0(或TR1)置1时,相应的T0或T1才能选通工作。,且选定用于模式2的计数方式,现在T0引脚上输入周期为1ms的脉冲,问:(1)此时定时器/计数器0的实际用途是什么(2)在什么情况下,定时器/计数器0溢出答:(1)此时定时器/计数器0的实际用途是0。1S脉冲信号发生器。(2)当T0每记数100次后定时器/计数器0溢出。=12MHz,定时器0的初始化程序和中断服务程序如下:oscMAIN:MOVTH0,#9DHMOVTL0,#0D0HMOVTMOD,#01HSETBTR0…中断服务程序:MOVTH0,#9DHMOVTL0,#0D0H…RETI问:(1)该定时器工作于什么方式(2)相应的定时时间或计数值是多少答:(1)该定时器以模式1工作于定时方式。(2)相应的定时时间为25。136ms.:..8051单片机的f=6MHz,如果要求定时时间分别位和5ms,当T0工作在模式0、osc模式1和模式2时,分别求出定时器的初值。答:(1)定时时间分别位时:模式0初值为8142、模式1初值为65486,模式2初值206。(2)定时时间分别位5ms时:模式0初值为5692、模式1初值为63036,模式2此时定时时间不够。,每计数1000个脉冲后,定时器1转为定时工作方式。定时10ms后,又转为计数方式,如此循环不止。设f=6MHz,试用模式1编程。osc解:先确定T1作为计数器时初值为:64536(0FC68H)T1作为定时器时初值为:60536(0EC78H)程序:SETBTR1LOOP:MOVTMOD,#50HMOVTH1,#0FCHMOVTL1,#68HAA:JBCTF1,AAMOVTMOD,#10HMOVTH1,#0E0HM