1 / 18
文档名称:

单片机原理及接口技术(C51编程)(第2版)-习题问题详解汇总情况.pdf

格式:pdf   大小:1,564KB   页数:18页
下载后只包含 1 个 PDF 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

单片机原理及接口技术(C51编程)(第2版)-习题问题详解汇总情况.pdf

上传人:1781111**** 2024/5/11 文件大小:1.53 MB

下载得到文件列表

单片机原理及接口技术(C51编程)(第2版)-习题问题详解汇总情况.pdf

相关文档

文档介绍

文档介绍:该【单片机原理及接口技术(C51编程)(第2版)-习题问题详解汇总情况 】是由【1781111****】上传分享,文档一共【18】页,该文档可以免费在线阅读,需要了解更多关于【单片机原理及接口技术(C51编程)(第2版)-习题问题详解汇总情况 】的内容,可以使用淘豆网的站内搜索功能,选择自己适合的文档,以下文字是截取该文章内的部分文字,如需要获得完整电子版,请下载此文档到您的设备,方便您编辑和打印。:..1章思考题及****题1参考答案一、,、存储器、和I/O口三部分,通过内部总线连接在一起,集成于一块芯片上。。。、软硬件资源利用最优化,从而大大降低成本和提高可靠性二、,。、,不属于单片机的应用范围。、。,片内多出了4KB的Flash程序存储器、128B的RAM、1个中断源、1个定时器(且具有捕捉功能)。。。(ISP),而AT89C52则不能。对:..,可将芯片AT89C51直接用芯片AT89S51替换。,可将芯片AT89S51直接用芯片AT89S52替换。,而复杂的数字信号处理运算及高速的测控功能则是DSP的长处。对第2章思考题及****题2参考答案一、,如果采用6MHz晶振,一个机器周期为2μs。。,位地址为40H、88H的位,该位所在字节的字节地址分别为28H和88H。;片内字节地址为A8H单元的最低位的位地址为A8H。,那么,P标志位的值为0。,R4所对应的存储单元的地址为04H,因上电时PSW=00H。这时当前的工作寄存器区是0组工作寄存器区。,可作为工作寄存器区的单元地址为H~H。答:00H,,首先要把的内容入栈,以进行断点保护。调用子程序返回指令时,再进行出栈保护,把保护的断点送回到,先弹出的是原来中的内容。答:PC,PC,,因为AT89S51单片机的PC是16位的,因此其寻址的范围为KB。答:,P0P3口的各引脚为电平。答:,引脚XTAL1接片外振荡器的输出信号,引脚XTAL2的接法是悬空。文案:..,堆栈指针SP中的内容为,程序指针PC中的内容为。答:07H,0000H二、,当前PC的值是。。。?,其运算速度越快。。三、=1时,仍可外扩64KB的程序存储器。。,为使准双向的I/O口工作在输入方式,必须事先预置为1。。(SFR)使用片内RAM的部份字节地址。,只能供位寻址使用,而不能进行字节寻址。,它们的位都是可以用软件设置的,因此,都是可以位寻址的。,与RAM无关。,CPU停止工作。片内的外围电路(如中断系统、串行口和定时器)仍将继续工作。对文案:..,片内RAM和SFR中的内容均保持原来的状态。,CPU和片内的外围电路(如中断系统、串行口和定时器)均停止工作。。对四、?答:集成了如下部件:1个CPU;128个数据存储器(RAM)单元;8KFlash程序存储器;4个8位可编程并行I/O口(P0口、P1口、P2口、P3口);1个全双工串行口;3个16位定时器/计数器;1个看门狗定时器;一个中断系统,6个中断源,2个优先级;32个特殊功能寄存器(SFR)。,请写出这些单元的入口地址及对应的中断源。答:见下表表AT89S51各中断源的中断入口地址中断源入口地址外部中断00003H定时器/计数器T0000BH外部中断10013H定时器/。答:当EA脚为高电平时,单片机读片内程序存储器(4K字节Flash)中的内容,但在PC值超过0FFFH(即超出4K字节地址范围)时,将自动转向读外部程序存储器内的程序;当EA脚为低电平时,单片机只对外部程序存储器的地址为0000H~FFFFH中的内容进行读操作,单片机不理会片内的4K字节的Flash程序存储器。文案:..第3章思考题及****题3一、,C51语言具有、、、等优点。答:可读性好,可移植性好,模块化开发与资源共享,,以及的说明。答:片内的外设硬件资源,。答:xdata,。答:,所有变量都默认位于8051单片机。答:“*”和“&”运算符来提取指针变量的和变量的。答:内容,地址二、。,函数是一个完成一定相关功能的执行代码段,它与另外两个名词“子程序”和“过程”用来描述同样的事情。,编写中断服务函数时需要考虑如何进行现场保护、阻断其他中断、返回时自动恢复现场等处理的程序段的编写。,它只在该函数内部有效。,由于全局变量一直存在,占用了大量的内存单元,且加大了程序的耦合性,不利于程序的移植或复用。对6..h定义了几个宏,用来确定各类存储空间的绝对地址。对三、,扩展了哪几种数据类型?答:扩展了4种数据类型,它们是:bit、sfr、sfr16和sbit。?其中数据类型“idata,code,xdata,pdata”各对文案:..应AT89S51单片机的哪些存储空间答:C51有6种数据存储类型data、bdata、idata、xdata、pdata和code。数据存储类型idata对应片内RAM的256字节。数据存储类型code对应程序存储区。数据存储类型xdata对应片外64KB的RAM空间。数据存储类型pdata对应片外RAM的256字节。?答:bit是用来定义普通的位变量,它的值只能是二进制的0或1。而sbit定义的是特殊功能寄存器的可寻址位,它的值是可以进行位寻址的特殊功能寄存器的某位的绝对地址,例如PSW寄存器OV位的绝对地址0xd2。(1)SMALL模式(PACT模式(3)LARGE模式之间的差别。答:3种数据存储模式之间的差别如下:(1)SMALL模式。在该模式下,所有变量都默认位于8051单片机内部的数据存储器,这与使用data指定存储器类型的方式一样。在此模式下,变量访问的效率高,但是所有数据对象和堆栈必须使用内部RAM。(PACT模式。本模式下的所有变量都默认在外部数据存储器的1页(256字节)内,这与使用pdata指定存储器类型是一样的。该存储器类型适用于变量不超过256字节的情况,此限制是由寻址方式决定的,相当于使用数据指针***@Ri进行寻址。与SMALL模式相比,该存储模式的效率比较低,对变量访问的速度也慢一些,但比LARGE模式快。(3)LARGE模式。在LARGE模式下,所有变量都默认位于外部数据存储器,相当于使用数据指针***@DPTR进行寻址。通过数据指针访问外部数据存储器的效率较低,特别是当变量为2字节或更多字节时,PACT产生更多的代码。-while构成的循环与while循环的区别是什么?答:(1)while语句。while语句的语法形式为:文案:..while(表达式){循环体语句;}表达式是while循环能否继续的条件,如果表达式为真,就重复执行循环体语句;反之,则终止循环体内的语句。while循环的特点在于,循环条件的测试在循环体的开头,要想执行重复操作,首先必须进行循环条件的测试,如果条件不成立,则循环体内的重复操作一次也不能执行。(2)do-while语句。dowhile语句的语法形式为:do{循环体语句;}while(表达式);do-while语句的特点是先执行内嵌的循环体语句,再计算表达式,如果表达式的值为非0,则继续执行循环体语句,直到表达式的值为0时结束循环。由do-while构成的循环与while循环十分相似,它们之间的重要区别是:while循环的控制出现在循环体之前,只有当while后面表达式的值非0时,才可能执行循环体,在do-while构成的循环中,总是先执行一次循环体,然后再求表达式的值,因此无论表达式的值是0还是非0,循环体至少要被执行一次。四、,将单片机片外2000H为首地址的连续10个单元的内容,读入到片内RAM的40H49H单元中。答:将片外2000H为首地址的连续10个单元的内容,读入到片内RAM的40H~49H单元中。程序如下:文案:..xdataunsignedcharbuffer1[10]_at_0x2000;dataunsignedcharbuffer2[10]_at_0x40voidmain(void){unsignedchari;for(i=0;i<10;i++){buffer2[i]=buffer1[i]}},函数内不包括这组RAM单元的起始地址和单元个数,起始地址和单元个数参数应在执行函数前由主函数赋值。答:参考程序如下:#defineucharunsignedcharvoidclear0(uchar*addr,ucharlenth){uchari;for(i=0;i<lenth;i++){*addr=0;addr++;}{voidmain(void){ucharaddr[32]_at_0x30;起始地址赋值ucharlenth=32;单元个数赋值clear0(addr,lenth);while(1);}文案:..第5章思考题及****题5参考答案一、,要采用电平输出。答:,只需把开关一端接到I/O端口的引脚上,另一端接地,然后通过检测来实现。答:I/O端口引脚的电平3.“8”字型的LED数码管如果不包括小数点段共计段,每一段对应一个发光二极管,有和两种。答:7,共阳极,,显示字符“6”(a段对应段码的最低位)的段码为,对于共阳极带有小数点段的数码管,显示字符“3”的段码为。答:7DH,(a段为最低位),此时显示器显示的字符为。答::显示闪烁,亮度,比较容易,但是占用的线较多。答:无,较高,软件控制,I/,一般采用显示方式,这样可以降低,减少的数目。答:动态,成本,I/,在其显示字符时,只需将待显示字符的由单片机写入LCD1602的显示数据RAM(DDRAM),内部控制电路就可将字符在LCD上显示出来。答:字符,ASCII码文案:..,还有字节的自定义,用户可自行定义个5×7点阵字符。答:80,显示数据,64,字符RAM,,应采用式键盘。当按键数目为64个时,应采用式键盘。答:独立,,对独立式键盘而言,8根I/O口线可以接个按键,而对矩阵式键盘而言,8根I/O口线最多可以接个按键。答:8,:首先,然后,随后,最后。答:读忙标志位BF,写命令,写显示字符,自动显示字符二、,它是一个双向口。,外部引脚必须接上拉电阻,因此它是一个准双向口。~P3口作为输入端口用时,必须先向端口寄存器写入1。~P3口的驱动能力是相同的。,动态显示所占用的I/O口多,为节省I/O口与驱动电路的数目,常采用静态扫描显示方式。,就可造成“多位同时亮”的假象,达到多位LED数码管同时显示的效果。,可由芯片内部硬件扫描电路自动完成显示数据的扫描刷新,和键盘扫描。,实质上就是控制加到行线和列线上的电平编码来控制点亮某些发光二极管(点),从而显示出由不同发光的点组成的各种字符。×16点阵显示屏是由4个4×4的LED点阵显示器组成。,可显示2行,每行16个字符。对文案:..。×8的非编码键盘提供接口电路,在接口电路中需要提供两个8位并行的输入口和一个8位并行的输出口。,同一时间只有一个数码管被点亮。,任一时刻只有一个LED数码管处于点亮状态,是LED的余辉与人眼的“视觉暂留”造成数码管同时显示的“假象”。对三、?各有什么优缺点?答:静态显示时,欲显示的数据是分开送到每一位LED上的。而动态显示则是数据是同时送到每一个LED上,再根据位选线来确定是哪一位LED被显示。静态显示亮度很高,但口线占用较多。动态显示口线占用较少,但是需要编程进行动态扫描,适合用在显示位数较多的场合。第6章思考题及****题6参考答案一、。定时器T1的中断入口地址为001BH。(IP)=00010100B,则优先级最高者为外部中断1,最低者为定时器T1。,产生长调用指令LCALL,执行该指令的过程包括:首先把的内容压入堆栈,以进行断点保护,然后把长调用指令的16位地址送入,使程序执行转向中的中断地址区。答:PC、PC、,中断优先级最高的中断源是外部中断0。,必须用软件清除的中断请求标志是串行中断、定时器/计数器T2中断。文案:..二、()。,将形成阻塞,,,需要外加电路实现中断撤销的是()。,在下列各种AT89S51单片机运行情况下,能立即进行响应的是()。,,()。,,,,都会标记在AT89S51的TCON、SCON寄存器中三、。,并且CPU开中断,CPU才可能响应中断。错文案:..。,外部中断0能打断正在执行的外部中断1的中断服务程序。。,只要中断源发出中断请求,CPU就会立刻响应中断。错四、?答:一个中断源的中断请求被响应,必须满足以下条件:(1)总中断允许开关接通,即IE寄存器中的中断总允许位EA=1。(2)该中断源发出中断请求,即该中断源对应的中断请求标志为“1”。(3)该中断源的中断允许位=1,即该中断被允许。(4)无同级或更高级中断正在被服务。第7章思考题及****题7参考答案一、,定时器/计数器Tx(x=0,1)工作在方式0、1、2下,,,方式2的最大定时时间为1024μs。,外部输入的计数脉冲的最高频率为系统时钟频率的1/24。,其计数脉冲由系统时钟信号12分频后提供,定时时间与定时器初值有关。,采用方式1定时方式可得到最大量程?若时钟频率为6MHz,。:、和,可通过对寄存器中的相关位进行软件设置来选文案:..择。,若利用定时器T1的方式1定时2ms,则(TH1)=FCH,(TL1)=18H。二、,定时器T1有种工作方式。、T1工作于方式1时,其计数器为位。、T1的GATEx=1时,其计数器是否计数的条件。,其计数器为位。,特殊功能寄存器TMOD的内容应为。、、T1的哪些说法是正确的。,与定时器/计数器的控制无关。,与定时器/计数器的控制无关。,与定时器/计数器的控制无关。,与定时器/计数器的控制无关。、T1对外部脉冲进行计数时,要求输入的计数脉冲的高电平或低文案:..电平的持续时间不小于1个机器周期。特殊功能寄存器SCON与定时器/计数器的控制无关。、T1对外部引脚上的脉冲进行计数时,要求输入的计数脉冲的高电平和低电平的持续时间均不小于2个机器周期。对四、、T0的工作方式2有什么特点?适用于哪些应用场合?答:方式2为初值自动装入的8位定时器/计数器,克服了在循环定时或循环计数应用时就存在用指令反复装入计数初值影响定时精度的问题。,定时器/计数器工作在方式0、1、2下,其最大定时时间各为多少?答:晶振的频率为24MHz,。方式0最大定时时间=×213=×8192=4096μs方式1最大定时时间=×216=×65536=327686μs方式2最大定时时间=×28=×256=128μs五、,要求使用T0,采用方式2定时,,占空比为10:1的矩形脉冲。答:据题意,:1,。如果系统采用6MHz晶振的话,Tcy=2μs,因此高低电平输出取整,则约为364μs和36μs。参考程序如下:ORG0000HLJMPMAINORG000BHLJMPIT0PMAIN:MOVTMOD,#02H;定时器/计数器T0为定时方式2MOVTL0,#4AH;定时364μs初值赋值SETBTR0;启动T0,开始计数SETBET0;允许T0中断SETBEA;:AJMPWAITIT0P:;关中断MOVR0,#9文案:..DLY:DJNZR0,DLY;延时36μsMOVTL0,#4AH;、填空1、AT89S51的串行异步通信口为(单工/半双工/全双工)。。,每帧10位,。。在串行通讯中,发送时要把并行数据转换成串行数据。接收时又需把串行数据转换成并行数据。,为减小波特率误差,。,方式1和方式3的波特率是可调的,与定时器/计数器T1的溢出率有关,另外两种方式的波特率是固定的。,8个数据位和1个停止位的异步串行通信方式是方式。答:方式1。,收发双方对波特率的设定应该是相同的的。。方式1波特率=(2SMOD/32)×定时器T1的溢出率二、,串行接口工作方式选择。文案:..。、。。,指令把TB8位的状态送入发送SBUF中。。,通过定时器/计数器T1的溢出率设定。,为fosc/32。,一定要占用一个定时器作为波特率发生器。,定时器方式2能产生比方式1更低的波特率。,但实际上它们是两个不同的寄存器。对四、,接收方是如何知道发送方开始发送数据的?答:实质就是如何检测起始位的开始。当接收方检测到RXD端从1到0的负跳变时就启动检测器,接收的值是3次连续采样,取其中2次相同的值,以确认是否是真正的起始位的开始,这样能较好地消除干扰引起的影响,以保证可靠无误的开始接受数据。?有几种帧格式?各种工作方式的波特率如何确定?答:有4种工作方式:方式0、方式1、方式2、方式3;文案:..有3种帧格式,方式2和3具有相同的帧格式;方式0的发送和接收都以fosc/12为固定波特率,方式1的波特率=2SMOD/32×定时器T1的溢出率方式2的波特率=2SMOD/64×fosc方式3的波特率=2SMOD/32×,传送数据的帧格式由1个起始位(0)、7个数据位、1个偶校验和1个停止位(1)组成。当该串行口每分钟传送1800个字符时,试计算出它的波特率。答:串口每秒钟传送的字符为:1800/60=30个字符/秒所以波特率为:30个字符/秒×10位/个字符=300b/s文案