我想用51单片机定时器中断程序一在方式一下延时一秒的函数。但是实际结果很快。不正常

延时与中断出错,是单片机新手在单片机开发应用过程中,经常会遇到的问题,本文汇总整理了包含了MCS-51系列单片机、MSP430单片机、C51单片机、8051F的单片机、avr单片机、STC89C52、PIC单片机…..在内的各种单片机常见的延时与中断问题及解决方法,希望对单片机新手们,有所帮助!

1、单片机延时程序的延时时间怎么算的?

答:如果用循环语句实现的循环,没法计算,但是可以通过软件仿真看到具体时间,但是一般精精确延时是没法用循环语句实现的。

如果想精确延时,一般需要用到定时器,延时时间与晶振有关系,单片机系统一般常选用11.059 2 MHz、12 MHz或6 MHz晶振。第一种更容易产生各种标准的波特率,后两种的一个机器周期分别为1 μs和2 μs,便于精确延时。本程序中假设使用频率为12 MHz的晶振。最长的延时时间可达216=65 536 μs。若定时器工作在方式2,则可实现极短时间的精确延时;如使用其他定时方式,则要考虑重装定时初值的时间(重装定时器初值占用2个机器周期)。

2、求个单片机89S51 12M晶振 用定时器延时10分钟,控制1个灯就可以

答:可以设50ms中断一次,定时初值,TH0=0x3c、TL0=0xb0。中断20次为1S,10分钟的话,需中断12000次。计12000次后,给一IO口一个低电平(如功率不够,可再加扩展),就可控制灯了。

而且还要看你用什么语言计算了,汇编延时准确,知道单片机工作周期和循环次数即可算出,但不具有可移植性,在不同种类单片机中,汇编不通用。用c的话,由于各种软件执行效率不一样,不会太准,通常用定时器做延时或做一个不准确的延时,延时短的话,在c中使用汇编的nop做延时

3、51单片机C语言for循环延时程序时间计算 ,设晶振12MHz,即一个机器周期是1us。

不可能的,是不是你的编译有错的啊

我改的晶振12M,在KEIL 4.0 里面编译的,为你得出的结果最大也就是40ms,这是软件的原因,

不可能出现100ms那么大的差距,是你的软件的原因。

不信你实际编写一个秒钟,利用原理计算编写一个烧进单片机和利用软件测试的秒程序烧进单片机,你会发现原理计算的程序是正确的

4 、51单片机c语言 _nop_()是一个空指令?短时间延时的?空几个机器周期?

答:这个_nop_()等效与汇编里面的,NOP指令,也就是空一个机器周期,如果是传统51单片机的话,等于空12个时钟周期【即一个机器周期】

5、51单片机 延时500ms 用机器周期叠加怎么算?

6、51单片机C语言程序中延时函数delay的原理是什么?

(1):延时函数的原理?

(2):两个for循环的作用?

(3):i、j的取值有什么规律和依据?是不是和单片机接的晶振频率有关?所能延时的最小单位时间是怎么计算的?

1:原理:仅仅执行一些,没有实质性影响的所谓“无意义指令”,比如做比大小啊,做某个int的自加运算啊之类的

2:两重for的作用:简单的说,就像高中数学中的“乘法原理”一样,这样可以很轻易的迅速增加上述“无意义指令”的数目

3:关于取值大小:这个如果是在C下变成,这个值不仅仅与晶振、单片机本身运算速度有关,而且还与C的编译器有关,所以说,这个值虽说是可以精确计算的,但大多数情况下,程序员用的都是“经验值”——当然,如果用汇编编程,情况就不一样了,因为每一条指令所使用的机器周期是一定的,你当然可以根据所有指令使用的总时间,精确的算出具体延时的总时间

综合你的的问题,我给你一点建议,就是刚学单片机的时候,还是一定要老老实实的从汇编编程学起——这样,在你以后接触到C之后,你才能明白,这中间实际上经历了一个什么样的过程,只有这样你才能真正理解单片机。当然,等最终你完全拿下一种单片机之后,尽量使用C编程,无疑是历史所肯定的。

7、51单片机,晶振为6M,求一个10ms的延时程序

答:延时有很多种方法,有一种是让单片机去做无聊的循环,还有一种是用定时器。

单片机花12个T1去执行一个指令,

所以一个机器周期等于12个晶振周期,

所以你要得到10ms的延时就要想办法让机器去做5000条“无聊的指令”

这种方法是用于对时间要求不高的地方,我说的是其思想,程序中可能有错的地方

用定时器的方法我不太会就不误人了 (补充一下就是这个是用汇编写的,你在主程序中用ACALL DEL调用就延时了。

8、今天我用单片机做“眨眼的LED”实验时,程序运行,每次只令灯亮或灭都没问题,但是一开延时不能出现期盼的灯亮灯灭的现象,这是怎么回事?

实验的硬件条件是:STC89C52,编译环境:keil 3。

下面是我写的程序,请教高手!!!

延时与中断出错,是单片机新手在单片机开发应用过程中,经常会遇到的问题,本文汇总整理了包含了MCS-51系列单片机、MSP430单片机、C51单片机、8051F的单片机、avr单片机、STC89C52、PIC单片机…..在内的各种单片机常见的延时与中断问题及解决方法,希望对单片机新手们,有所帮助!

一、单片机延时问题20问

1、单片机延时程序的延时时间怎么算的?

答:如果用循环语句实现的循环,没法计算,但是可以通过软件仿真看到具体时间,但是一般精精确延时是没法用循环语句实现的。

如果想精确延时,一般需要用到定时器,延时时间与晶振有关系,单片机系统一般常选用11.059 2 MHz、12 MHz或6 MHz晶振。第一种更容易产生各种标准的波特率,后两种的一个机器周期分别为1 μs和2 μs,便于精确延时。本程序中假设使用频率为12 MHz的晶振。最长的延时时间可达216=65 536 μs。若定时器工作在方式2,则可实现极短时间的精确延时;如使用其他定时方式,则要考虑重装定时初值的时间(重装定时器初值占用2个机器周期)。

2、求个单片机89S51 12M晶振 用定时器延时10分钟,控制1个灯就可以

答:可以设50ms中断一次,定时初值,TH0=0x3c、TL0=0xb0。中断20次为1S,10分钟的话,需中断12000次。计12000次后,给一IO口一个低电平(如功率不够,可再加扩展),就可控制灯了。

而且还要看你用什么语言计算了,汇编延时准确,知道单片机工作周期和循环次数即可算出,但不具有可移植性,在不同种类单片机中,汇编不通用。用c的话,由于各种软件执行效率不一样,不会太准,通常用定时器做延时或做一个不准确的延时,延时短的话,在c中使用汇编的nop做延时

3、51单片机C语言for循环延时程序时间计算 ,设晶振12MHz,即一个机器周期是1us。

不可能的,是不是你的编译有错的啊

我改的晶振12M,在KEIL 4.0 里面编译的,为你得出的结果最大也就是40ms,这是软件的原因,

不可能出现100ms那么大的差距,是你的软件的原因。

不信你实际编写一个秒钟,利用原理计算编写一个烧进单片机和利用软件测试的秒程序烧进单片机,你会发现原理计算的程序是正确的

4 、51单片机c语言 _nop_()是一个空指令?短时间延时的?空几个机器周期?

答:这个_nop_()等效与汇编里面的,NOP指令,也就是空一个机器周期,如果是传统51单片机的话,等于空12个时钟周期【即一个机器周期】

5、51单片机 延时500ms 用机器周期叠加怎么算?

6、51单片机C语言程序中延时函数delay的原理是什么?

(1):延时函数的原理?

(2):两个for循环的作用?

(3):i、j的取值有什么规律和依据?是不是和单片机接的晶振频率有关?所能延时的最小单位时间是怎么计算的?

延时时间怎么计算啊!假如用的是AT89C51RC+11.0592M的晶振呢?

1:原理:仅仅执行一些,没有实质性影响的所谓“无意义指令”,比如做比大小啊,做某个int的自加运算啊之类的

2:两重for的作用:简单的说,就像高中数学中的“乘法原理”一样,这样可以很轻易的迅速增加上述“无意义指令”的数目

3:关于取值大小:这个如果是在C下变成,这个值不仅仅与晶振、单片机本身运算速度有关,而且还与C的编译器有关,所以说,这个值虽说是可以精确计算的,但大多数情况下,程序员用的都是“经验值”——当然,如果用汇编编程,情况就不一样了,因为每一条指令所使用的机器周期是一定的,你当然可以根据所有指令使用的总时间,精确的算出具体延时的总时间

综合你的的问题,我给你一点建议,就是刚学单片机的时候,还是一定要老老实实的从汇编编程学起——这样,在你以后接触到C之后,你才能明白,这中间实际上经历了一个什么样的过程,只有这样你才能真正理解单片机。当然,等最终你完全拿下一种单片机之后,尽量使用C编程,无疑是历史所肯定的。

7、51单片机,晶振为6M,求一个10ms的延时程序

答:延时有很多种方法,有一种是让单片机去做无聊的循环,还有一种是用定时器。

单片机花12个T1去执行一个指令,

所以一个机器周期等于12个晶振周期,

所以你要得到10ms的延时就要想办法让机器去做5000条“无聊的指令”

这种方法是用于对时间要求不高的地方,我说的是其思想,程序中可能有错的地方

用定时器的方法我不太会就不误人了 (补充一下就是这个是用汇编写的,你在主程序中用ACALL DEL调用就延时了。

8、今天我用单片机做“眨眼的LED”实验时,程序运行,每次只令灯亮或灭都没问题,但是一开延时不能出现期盼的灯亮灯灭的现象,这是怎么回事?

实验的硬件条件是:STC89C52,编译环境:keil 3。

下面是我写的程序,请教高手!!!

{;} //可算得本次循环延时约1MS

Delay(1000); //应单片执行程序的时间很快,所以必须延时,要不看不到实验现象

补充提问:我是让P1.0先低然后延时之后再高,即灯先亮再灭,然后开始循环的

Delay(1000); //应单片执行程序的时间很快,所以必须延时,要不看不到实验现象

补充问题回复:问题恰恰就错在这了,循环完一遍之后灯由灭到亮根本没有时间延时,即第一次循环中灯还没来的机灭呢,就进入到第二轮循环中的亮了,所以原因就在这,这错误太低级了,以后引以为鉴吧

9、单片机延时函数的问题

这个函数中的i,j的大小有**吗?

答:这个函数中j的大小和你定义的数据类型有关,因为你定义的为无符号字符型,为单字节数据,所以最大为255。.

如果你需要增大,可以改变j的数据类型定义,如unsigned int (2字节)可以到65535;无符号长整形unsigned long(4字节) 可以到。 而上面所所256是-1,而你定义的是无符号字符型。

10、请教一个AVR单片机延时的问题

外部晶振用的是8MHz,延时1微秒的程序如下:

请问,为什么能延时1微秒啊?

答:8MHZ表示单片机的运行周期为1/8us,也就是0.125us执行一步

那么包括程序的提取,执行等都要花费时间

比如,你提取这个函数可能花去一步,那现在就使用了0.125us啦

接着你执行这个函数,在单片机内部,运算是通过寄存器的移来移去实现的

这都需要时间,可能你看到的就一句counter--这个指令,可能会花费好几个时钟周期来实现

c=a+b,只有一句,但实际上花费的时间并不短

add a,b;//寄存器a的值与b相加,结果放入a

这样才是单片机内部真正执行的指令,这需要花费至少4个时钟周期,而不是1个

至于晶体管级的我就不解释了,你得好好学习汇编才能理解单片机的运作。

至于这个函数为什么能延时1ms,这个是靠经验来判断的,最直接的方法就是用示波器看,以上均为推论。

11、PIC单片机的延时问题 晶振4Mhz:
此函数在4M晶体下产生10003us的延时,也就是10MS。
问题:我刚算了一下他应该执行了999条指令,1条单周期的指令也才1US,那就是999us,为什么会有10ms的延时?
第一句:X的值范围是不是 1~99?为什么?
第二句:X的范围是不是0~99?为什么?这么算的。我知道符号在前在后的区别。2句话应该是不一样的才对啊!
问题1:“我刚算了一下他应该执行了999条指令”因为你算错了。延时时间是由产生的汇编代码所决定的,C语言语句只是个假象,千万不要以为C语言一行就是一条指令!此处由于涉及到双字节减法,因此会有额外的判断,编译结果每次循环耗费几十个周期毫不奇怪。

问题2:前一句x从100开始递减,递减至1时退出循环。后一句x从0开始递增,递增到100时退出循环。所谓“2句话”相同仅仅是指这两个循环体的循环次数相同。实际上两个循环的执行过程是完全不同的,所消耗时间也有可能不同。

13、我想用单片机连接不断地向电脑发数,如下:


如每发送一个数,应延时多少微妙好呢?即一般最短能延时多少微米呢?如延时太长的话,那发送很多数据不就用很长时间吗?

答:不做太多的串口处理分析,只顺着你的问题和你的方法说说:


先考虑下串口的速率 假设9600,那么发送一个字符要多久?
也就是说你如果在1ms内发送超过一个字符就没意义了,硬件速度达不到。
这个循环是执行周期也就十几微秒+delay()的延迟,所以任何小于1040微秒的延迟对串口硬件来说没意义,上一个还没处理完,下一个就来了根本执行不了嘛。
如果你send_char()里面有while(!TI);TI = 0;这样的语句或有串口中断TI的处理的话,那么实际上你的delay()已经在发送函数里了,while(!TI);这部就是延迟等待吗?那根本不需要主函数去延迟了,直接发就行了。

14、一个单片机延时子程序的问题,在延时子程序那里,一直搞不明白,给r7和r6赋予0,然后下面的djnz r7,delayloop不就一直循环了,那还怎么接下去的程序?

答: 你的延时程序不是因为值为0,而是跳转位置不对,改为如下:

15、我想提两个单片机延时与按键的问题


1:如果一个程序中延时和按键,如果延时子程序比较长(假如2秒),怎样确保按键能够得到及时响应(假如PC正在执行延时子程序,正在这时候有按键输入,不是响应不了)——,,,前提是不能用定时器定时扫描,和中断来做,因为定时器和中断我另有其他用途
2:单片机没有串口。怎样才能使得他与24C02进行通信(24C02是具有2K内存的EEPROM)
首先明确一点你说单片机没有串口,应该是指没有I2C口吧。
1 在延时程序里面加入按键的检测
2 用IO口模拟I2C时序读写

16、51单片机延时小程序,求高手解释什么意思?

17、于51单片机延迟时间的问题


这两条语句在12M晶振下运行时间分别是多少??
答:一个时钟周期,2us,共4us

18、周期为6MHZ的单片机延时10秒的子程序的怎么编?

19、片机的有些程序需要调用延时程序,如何能合理的安排循环次数以及空操作的个数?


答:用汇编的话就根据你的当前晶振频率去推算你的指令周期,然后结合你需要延迟的时间,编写延迟程序,用C的话还是要看最后生成的汇编码是什么样的了。最简单的方法就是写好程序以后再编译器里软仿真看时间。赞同2| 评论(1)

20、单片机延时程序问题

二、单片机中断问题30例

1、单片机外中断INT0为下降沿触发,当中断被触发后cpu执行中断程序,若本次中断的程序还未执行完INT0又来了一个相同的下降沿中断信号怎么办?cpu会怎么处理?若是定时器中断呢?串口中断呢?求解释


答:再来一个INT0信号不会执行。相同的优先级不会打断正在执行的中断。
一. 如果是高优先级的中断来了,会打断低优先级的正在执行的中断而执行高优先级的中断。
51单片机的默认(此时的IP寄存器不做设置)中断优先级为:
当同时有几种中断到达时,高优先级中断会先得到服务。
例如:当计数器0中断和外部中断1(优先级 计数器0中断>外部中断1)同时到达时,会进入计时器0的中断服务函数;但是在外部中断1的中断服务函数正在服务的情况下,这时候任何中断都是打断不了它的,包括逻辑优先级比它高的外部中断0计数器0中断。
51单片机的中断优先级控制寄存器IP可以把默认的中断优先级设置为高或低级,
现在设为定时1 和串行中断为高优先级 其它为低 ,那么中断0执行时会被定时器1 或串行中断打断,如果设定的两个高优先级定时/计数器1 和串行中断同时响应,会再自然排队,先执行定时1中断再执行串行中断。

2、单片机中断问题,中断3为什么不执行,整个程序有什么不对的地方呢?


程序运行一次就跑飞了!!!
//在这里加 死循环,等待中断
而且,中断响应函数里必须要清中断标志位(你的没有)!

3、各位大侠帮我看一下我写的51单片机C程序中断有没有问题,执行中断后不能继续执行主程序,注:P3.2口一直接


IT0=0;//低电平触发,只要单片机监测到是低电平,就触发中断
你P3.2一直接地,一直是低电平,那中断就不断的执行,当然回不到主程序中了。
改成IT0=1;//下降沿触发,单片机监测到高电平到电平跳变,就触发中断
就算P3.2一直接地,也只触发一次,中断执行完了,就回到主程序中了。

4、我的单片机这个程序为什么不能完全执行整个程序谁能告诉我!就是没法执行3次亮暗的!

我是想执行完流水灯亮.就然后执行全亮全暗3次 !可是就是不会跳到全亮全暗3次~~


说明:通过外部中断0【P3.2】,P1.0的数码管亮,中断结束后,数码管灭;再由外部中断1【P3.3】,P1.1的数码管亮,次中断结束后,数码管灭;简言之就是一个中断只控制一个数码管,中断之间在功能上没有必然的联系,编程环境keil C51。P1.0和P1.1口上接的都是普通LED小灯,数码管=LED小灯。

以下是我编的程序,就是一个中断控制一个数码管,但是当有两个中断时,我就抓瞎了

6、单片机中断问题,下面这段程序不知道为什么只进一次中断,就没有反应了呢?

这个程序上电后P0口显示0x32;按下key2显示0x3f;key1用于中断,每20ms检测是否有按下key1键,有的话,P0口显示0xf1。

由于p中1断中1A被设为10所以5中7断返回后对A移位没有意义,o A一e直为10 ,并不d是只能中断一1次 .
还有,不清楚key1是什么中断,貌似是键盘扫描吧,
都进入死循环了,所以跳不出来,就一次中断了。

7、新手学习avr单片机ATmage 128 遇到问题,中断程序被忽略问题,找不到原因。


avr studio 4 软件仿真时,编译通过了,单在编译信息栏却看到中断程序被忽略。在软件仿真时也发现中断程序没有执行。不知道问题出在哪里,我用的是avr studio 4 ATmage 128 单片机.

上面是写的程序。还有编译信息栏里的话。


看看,记住,这是GCCAVR 编译软件的写法

8\新学的C51单片机,编了个电平触发式中断程序,不知道为什么和跳变沿的一样了,诸位帮忙看看.

你这个程序中设置IT0=0,说明是低电平触发,所以只要P3^2口一直是低电平那么主程序停止,所以发光二极管点亮,如果P3^2口变为高电平,主程序继续,发光二极管熄灭。另一种情况是当IT0=1的时候是负跳变触发,就是当P3^2口检测到一个又高电平到低电平的跳变后,触发中断,在中断函数中点亮灯,立即出中断,执行到d1=1时熄灯。看到的现象就是灯闪一下,直到又检测到一个负跳变,灯又闪一下。两种触发方式的现象是不一样的,如果你硬件没问题的话。你可以把中断函数写成d1=!d1试试。

9、在C51单片机中,中断服务程序怎么撤销中断引脚上的低电平?


我用的是,第一个单片机输出低电平到第二个单片机的P3^2,第二个单片机是电平触发方式中断
低电平触发方式:要求低电平保持到CPU实际响应为止,为了避勉CPU再次响应中断,在中断服务程序中应该撤除中断引脚上的低电平。请问,怎么撤销?在中断服务程序中怎么写? 直接写P3^2=1;行吗?
第一个单片机的程序,是谁来编写? 如果也是楼主,那就好办了。
第二个单片机完成了中断的功能,在退出之前,可以向第一个单片机回送一个脉冲;
第一个单片机收到这个脉冲,就应该撤消送到第二个单片机的中断申请信号。
另外,如果能算出来完成中断的时间,第一个单片机送来的申请信号,就不要超过这个时间,应该及时、自动的撤消申请信号。
第一个单片机送来的申请信号,也不可过短,应该能让对方检测到。

10、程序如下,我想要得到的效果是1秒左边的电动机转动,同时黄灯亮,1秒右边转动,蓝灯亮,以此循环下去,但是这个程序用上去后,左边转》右边转》左边转》之后就一直是左边了,不切换了,谁能帮我解决下问题,感激不尽!!

11、求助关于51单片机外部中断的问题,小弟最近在学单片机,刚做了一个键盘扫描程序。发现如果外部中断为电平触发,程序能正常运行。但如果改为边沿触发,在将键值送给显示重开中断指令为EX0=1后,中断竟然还会被触发一次,这之后,再按键就不能触发中断了。如果将中断程序中关中断语句去掉,按键能被扫描,但引起中断的次数不好说了。请大侠们看看哪出问题了。谢谢


不需要每次在进入中断程序后开一次中断;EX0=1可以去掉。
实际上,外部中断工作在边沿触发方式的时候,第一次电平跳变触发后进入中断程序,然后硬件自动清除IE0中断标志位。但是在执行中断程序的过程中,如果中断引脚再次检测到电平跳变(负到高),那么IE0会被再次置1 。如果在退出中断程序之前没及时清0,那么就会再次引发一次中断。
而按键的过程,不包括按下和松开时的电平抖动,至少会产生两次电平跳转。
因此,只需在你中断程序里适当加一点延迟,再将EX=1, 改成IE0=0 。

12、我用的单片机是8051F的单片机,在程序中我用了两个中断。一个是定时计数器2产生的中断100MS一次的数据采集。另一个是向上位机发送采集来的数据,使用的串口来实现的,用的单片机的UART来实现。也是一个中断。这两个中断在一起工作时需要注意些什么?我的中断程序出了一些问题。


(就是默认情况下,UART的中断级别更高,但是有的时候UART的中断不能及时响应,这是为甚?)
之前和你做的一样就两个中断 UART0加一个定时器 我用的是C
你向上位机发送数据使用UART0时 要确认定时器工作完毕
T2定时中断后 你加一个完成标志如T2FLAG
你100ms的中断时间 C8051这么快速的单片机怎么都该发送完成了吧。

13、MSP430单片机中断嵌套,如何跳出中断?


当进行A中断时,来了一个B中断,我想让B中断程序执行完后不继续
执行A中断而跳出整个中断,去执行主程序,请问这个怎么设置呢?
中断的时候会把SR状态跟中断下来要执行语句的地址放进堆栈中,实现处理完中断以后cpu要执行的语句,注意是地址先进,SR后进,出栈时SR先出,地址后出,当然了在中断里面可以嵌套中断的,对可屏蔽中断来说,主要是CPU响应中断以后,GIE会自动复位,所以不能对可屏蔽中断进行嵌套,如果在中断中要嵌套可屏蔽中断的话可以开GIE,但要注意的是如果此时正在响应的中断标志还是置位的情况下会反复进入此中断,就像死循环一样,这时会引起堆栈的溢出,而在响应可屏蔽中断时,不可屏蔽中断不受此影响,因为他不受GIE的影响,只受自己单独的使能位影响。在堆栈中的操作原理类似。

14、MSP430单片机有几个需要软件清除的中断标志?如何清除?


(1)清除各个端口的外中断用:PxIFG,相应的位置0即可;
(2)清除Timer中断用:TAIFG,TBIFG,相应的位置0即可;
MSP430的16个外中断比如软件清除Flag,在进入外中断后,首先要做的就是把相应的PxIFG清0;
而定时器Timer中断是自动清除Flag;
还有在中断嵌套的时候会用到,在进入中断后,MCU会自动把全局中断位GIE清零,这样在进入本中断后就不会再相应其他中断,若要进行中断嵌套,必须在进入中断后把GIE再置1.

15、MCS-51系列单片机的有几个中断源?各中断标志是如何产生的?如何清除各中断标志?


标准51有5个中断向量(不算复位),分别是外部中断0,定时器0,外部中断1,定时器1,串行口;总共有6个中断标志,串行口的发送和接受共享一个中断向量。
各个终端标志产生情况如下:
外部中断可以设置边沿触发或者电平触发,边沿触发进入中断程序后硬件自动清中断标志,电平触发需要软件清标志位;
定时器T0,T1计数溢出产生中断,进入中断程序硬件自动清标志位;
串行口发送完成或者接收到数据就触发中断,由于是两个中断标志共享一个中断向量,所以需要在中断程序里由软件判断是发送中断还是接受中断,并且只能由软件清标志位;

以上是标准51的中断系统,52由于多了一个T2定时器(T2定时器跟T0,T1功能相差很大,T2要强大很多),因此多了一个中断向量2个中断标志(溢出中断和T2外部中断),T2中断标志必须由软件清除标志位

16、MCS51单片机的汇编语言的中断服务程序最多有几个?


答:一般而言有5个对:2个外中断 ,2个定时器中断, 1个串口中断。
但是单片机的中断服务资源是根据硬件的结构设计,会有不同的数量和类型的中断服务,,,因此中断并不是对语言来讲的,而是对于硬件资源来讲的。比如52有6个中断。
基于语言编译器来讲,我就举例个人感觉最好的开发51大系列的开发环境Keil,其编译器最多支持32个中断服务,,,,因此中断对编译来说,是一个“模拟”的概念。

18、单片机中断程序的书写步骤?

19、我想知道单片机的蜂鸣器音乐程序中断是如何响应的?从main主程序中如何到中断程序?具体步骤是啥?谢谢! 就是等待中断的意思,这个程序中的定时器中断没有设置初值,所以中断几乎没有等待,时时触发(要是有等待时间,音乐不就连不上了么)。综上:这个定时器中断完成两个任务:1、使单片机时时触发(等待时间几乎为0);2、控制了音符的演奏频率。
再往下 while(time) 的循环就是为演奏的音符赋值的操作了。

20、单片机中断该什么时候进如?


中断看是外部中断、定时器还是串行口中断了。
如果是外部中断,就是p3.2、p3.3检测到这两个口电平变化时(假设这两个口接上按键,那么当按键按下时表明产生中断),然后跳到中断程序执行。
如果是定时器中断的话,有个中断标志位TFx(x表示0或者1),比如说你设置一个1S的定时器程序,你以50ms为基准,20次产生1s的时间,然后当50ms一过,标志位就产生变化,进入定时器中断程序执行!
串行口中断也是一样有一个标志位,接受或者发送数据满了以后,标志位就发生变化,然后进入中断执行!

21、PIC单片机AD中断什么时候开启,对AD中断应该怎样理解。
AD模数转换,是把模拟电压数值采样进来,然后转换成数字信号。这一采样和转换是需要时间的。并不是一开AD就能读到数字信号数据。
一般来说其时间都只有几微秒到几百微秒(根据设置不同而定)。如果单片机没有其他工作的时候,可以用循环等待的方式等AD转换结束(转换结束后DONE位会被置位)。但如果你的单片机还有其他工作,那就没必要在等待它上面花费时间。可以开AD操作后,继续执行其他程序。而转换结束后,AD中断可以暂时断开现有炒作,而把AD数据读进来。这就是AD中断的作用。

22\51单片机的五个中断分别在什么时候(什么情况)执行里面的程序!


定时器0中断:当定时器0计数到FFFF溢出时
定时器1中断:当定时器1计数到FFFF溢出时
串口中断:串口接收到一帧。或发送完一帧数据都会产生中断。
你网上找一下TCON和SCON。什么条件让中断标志位的值改变。 那么就会进入中断服务程序去。

23、51单片机,如果中断函数比较长,执行到一半又触发了这个中断,程序会停止从头执行,还是执行结束后响应中


51单片机中,中断分高低两个优先级,高优先级的中断能打断低优先级的中断。
但同级中断是不能打断同级中断的!无论该中断函数有多长,在执行到一半这个中断又发生了,还是要等到该中断函数执行完毕,并再执行了一条主程序指令后才会再次进入该中断。
不过,若楼主恰好在这个低优先级中断服务程序中修改了该中断为高优先级,那么如果该中断函数比较长,执行到一半又触发了这个中断,则该中断函数就会被重新从头开始执行(中断嵌套)。这是因为除串口中断以外的其他中断,在 CPU 响应该中断,程序转入该中断函数前就已经将该中断的中断标志清零了。
另外,51的串口中断比较特别,因为需要软件清除串口中断标志,所以只要在未清串口中断标志前,是不会发生上述这样的中断嵌套的。

24、求51单片机程序,两个计数器,主要是中断函数的函数名以及初始化设置

25、请教一个单片机中断的问题:比如来了一个脉冲,开始中断,但中断里的程序执行到一半时,又来了一个脉冲,请问这时中断里的程序是从头开始呢还是继续呢?


我的意思是程序就一个中断A,来了一个脉冲,A执行,A执行到一半时,又来了一个脉冲,通知A执行。这时A是从头执行还是先不理会呢?
需要具体情况具体分析,因为不同的单片机在中断机制上有细微的差别,需要查他的资料。
一般来说,一个中断源请求中断,对CPU来说,是一次性的做了一个“中断挂号”。假如当时因条件不满足(例如CPU正在“关中断”,即没有打开“中断允许”),而没有响应中断,则挂号信息还在,这样,将来一旦打开了中断允许,仍然会响应,只是晚了一点而已。
而中断响应以后,必须有办法把这个“中断挂号”消除掉。有的CPU的功能是:只要响应了这个中断,挂号就自动消除了。也有的CPU不能自动清除挂号,必须在中断服务程序中编入“清除中断挂号”的操作,否则,一旦打开了中断允许,它又会重复发生中断。

现在的大多数单片机里,中断控制器和CPU是在同一个芯片中,它可以做到自动消除中断挂号。而过去许多种CPU,所配用的中断控制器是另外一个芯片,自然就无法自动消除了。

也有的CPU中有另外一种“不挂号”的中断请求。它必须由外界(发出中断请求的那个设备)来保持一直不停申请,等到响应中断的时候,再设法(例如,在中断服务程序中发出一个输出信号)通知那个设备撤销申请。

大多数的CPU中,一旦响应中断进入了服务程序,就把“中断允许”关掉了。故此时如果又有下一个中断请求来了,不能立即响应,只能挂一个号,等以后“开中断”时才能再响应。如果程序员希望能够“嵌套中断”(即在一次中断服务程序的执行中途又进入了另一个中断服务程序),就需要在服务程序内编入“开中断”的操作。

“嵌套中断”原则上允许“自己嵌套自己”,也就是说,一次中断服务程序的执行中途又被打断并进入了和自己一样的中断服务程序,并从头到尾执行一遍,结束后返回到先前打断的那一点,并继续执行后半截服务程序。这种情况会产生什么效果,是需要程序员自己考虑的。

也有的CPU具有“优先次序”机制,可以在某一级的中断服务程序里禁止优先级不比自己高的其他中断来打断自己。同时,也提供给程序员有“放弃优先权”以及“修改优先级”的灵活性。


而被优先机制暂时“屏蔽”的那些较低优先级的中断申请,同样挂号仍在,以后高优先级的中断结束以后,还能响应。

不过需要注意,大多数的CPU中,“中断挂号”是只能挂一个的。也就是说,在前一次的中断申请所挂的号还没有被清除以前,又来了下一个中断申请,那么,第二个挂号是挂不上的。

不过某些处理器中,中断挂号可能分成几个层次:CPU里面是一层,外围针对各个具体的设备,还有另外一级“预备挂号”,那就比较复杂了。

另外多说几句:上面已经说,程序员可以自己决定你的中断服务程序允许还是不允许“嵌套”。

如果不允许,您可以采用关中断的办法,或者利用优先机制,来屏蔽同一中断源的第二个中断请求。


这样,第二个中断就不会被响应。但它仍可以挂上一个号(只要它发生在上一个中断挂号已经被清除掉以后的时间)。然后,中断服务程序结束时,一般都会开中断并释放优先级屏蔽。然后,第二个中断请求就会被响应,于是再一次执行中断服务程序。

如果允许“嵌套”,那就会如我上面所说:


一次中断服务程序的执行中途又被打断并进入了和自己一样的中断服务程序,并从头到尾执行一遍,结束后返回到先前打断的那一点,并继续执行后半截服务程序。

主程序最后,要加个死循环:while(1){};

还有,你在这用了方式1,这个方式在你进中断后,TH1和TL1会变成0000H。你不对他重新赋值,你要等FFFFH次计数,才会进中断。


28、我看很多程序都是主程序进入while(1),就死在while(1)里了,然后等待外中断。那么现在的问题是我想让它进入外中断完事后,跳过while(1),执行下边的程序,该怎么办?


while里边用break吗?不知道好使不好使,还有标志位我看是硬件自动清零,查询标志应该不能用吧,那该怎么办呢?
结束while(1)语句最好的方法就是使用break来跳出死循环,关键就是选择合适的flag(标志位),如果说中断标志位是硬件自动清零的话,那么楼主不妨在中断服务子程序中自己加入一个标志位:如果用汇编语言的话,PSW中的F0位就可以很好的使用;如果用C的话,就可以随便定义一个位变量,如bit a=0;。也就是说,楼主需要在程序中定义一个位变量a,在中断服务子程序中将a置1,退出中断后查询a是否为1,例如:if(a) {a=0;break;}这样就跳出了while语句了。
比方说,如果楼主想写一个等待按键按下中断的程序,就可以用while(!a);而不用while(1)语句了。

29、我用外部中断1,中断一次显示下一个数,数码管显示没问题。但是我用P3-3口用导线连接,接触一次地线,松开一次,这时候数码管显示会乱跳,有时候加两次数,有时候加好多次数,反正就是不稳定。假如p3-3口通过按键接地的话,按一次按键一般情况会加一次数,但有时候也是不稳定,可能中断好几次。


应该采取消抖措施,硬件、软件方法皆可。
楼主在中断函数中,延时,时间看来很是不短!
但是延时后,并没有检测按键是否还在按下,这就不能算是软件消抖。

30、 (1) 为什么单片机有两个外部中断0允许位?有什么作用?


(2)在51内核单片机中,当允许响应外部中断0的中断请求时,其特殊功能寄存器ie中的位必须为1 es exo ea et0?
(1)两个中断是因为一般的单片机有两个中断源,可以实现两级中断嵌套,在实现复杂功能上两级中断嵌套很有用。
EA--总中断允许位,必须为1
ES--串行中断允许位,不必开,为0
EX0--外部中断0允许位,应为1
ET0--定时计数溢出中断允许位,不必开,为0

篇一 : 单片机原理及应用完全参考答案

1.2 除了单片机这一名称之外,单片机还可称为(微控制器)和(嵌入式控制器)。(]

1.3 单片机与普通计算机的不同之处在于其将(微处理器)、(存储器)和(各种输入输出接口)三部分集成于一块芯片上。

4、单片机的发展大致分为哪几个阶段?

答:单片机的发展历史可分为四个阶段:

第一阶段(1974年----1976年):单片机初级阶段。

第二阶段(1976年----1978年):低性能单片机阶段。

第三阶段(1978年----现在):高性能单片机阶段。

第四阶段(1982年----现在):8位单片机巩固发展及16位单片机、32位单片机推出阶段

1.5 单片机根据其基本操作处理的位数可分为哪几种类型?

答:单片机根据其基本操作处理的位数可分为:1位单片机、4位单片机、8位单片机、16位单片机和32位单片机。

1.6 MCS-51系列单片机的基本芯片分别为哪几种?它们的差别是什么? 答:基本芯片为8031、8051、8751。

8031内部包括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.7 MCS-51系列单片机与80C51系列单片机的异同点是什么?

答:共同点为它们的指令系统相互兼容。不同点在于MCS-51是基本型,而80C51采用CMOS工艺,功耗很低,有两种掉电工作方式,一种是CPU停止工作,其它部分仍继续工作;另一种是,除片内RAM继续保持数据外,其它部分都停止工作。

(A)内部数据存储单元数目的不同 (B)内部数据存储器的类型不同

(C)内部程序存储器的类型不同 (D)内部的寄存器的数目不同

单片机原理及应用答案 单片机原理及应用完全参考答案

1.9 在家用电器中使用单片机应属于微型计算机的(B)

(A)辅助设计应用 (B)测量、控制应用 (C)数值计算应用 (D)数据处理应用

1.10 说明单片机主要应用在哪些领域?

答:单片机主要运用领域为:工业自动化;智能仪器仪表;消费类电子产品;通信方面;武器装备;终端及外部设备控制;多机分布式系统。[]

第二章 MCS-51单片机的硬件结构

2.1 MCS-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.3 MCS-51的时钟振荡周期和机器周期之间有何关系?

答:每12个时钟周期为1个机器周期。

单片机原理及应用答案 单片机原理及应用完全参考答案

2.4在MCS-51 单片机中,如果采用6 MHZ 晶振,1个机器周期为(2微秒)。[]

2.5程序存储器的空间里,有5个单元是特殊的,这5个单元对应MCS-51单片机5个中断源的中断入口地址,请写出这些单元的地址以及对应的中断源。

答: 中断源 入口地址

2.6 内部RAM中,位地址为30H的位,该位所在字节的字节地址为(26H)。

2.7 若A中的内容为63H,那么,P标志位的值为(0)。

2.8 判断下列说法是否正确:

(B)区分片外程序存储器和片外数据存储器的最可靠的方法是看其位于地址范围的低端还是高端。 (错)

(C)在MCS-51中,为使准双向的I/O口工作在输入方式,必须保证它被事先预置为1。 (对)

(D)PC可以看成是程序存储器的地址指针。 (对)

2.9 8031单片机复位后,R4所对应的存储单元的地址为(04H),因上电时PSW=(00H)。这时当前的工作寄存器区是(0)组工作寄存器区。

2.10 什么是机器周期?1个机器周期的时序是如何来划分的?如果采用12MHZ晶振,1个机器周期为多长时间?

答:CPU完成一个基本操作所需要的时间称为机器周期。时序划分:一个机器周期包括12个时钟周期,分为6个状态;S1-S6。每个状态又分为2拍;P1和P2。因此,1个机器周期中的12个时钟周期表示为:S1P1、S1P2、S2P1、S2P2、?、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中的RS1、RS0来切换当前的工作寄存器区,这种功能给软件设计带来极大的方便,特别是在中断嵌套时,为实现工作寄存器现场内容保护提供了方便;字节地址为20H-2FH的16个单元可进行工128位的位寻址,这些单元构成了1位处理机的存储器空间;字节地址为30H-7FH的单元为用户RAM区,只能进行字节寻址。用于作为数据缓冲区以及堆栈区。

2.15 判断下列说法是否正确

(A)程序计数器PC不能为用户编程时直接使用,因为它没有地址。 (对)

(B)内部RAM的位寻址区,只能供位寻址使用,而不能供字节寻址使用。 (错)

(C)8031共有21个特殊功能寄存器,它们的位都是可用软件设置的,因此,是可以进行位寻址的。 (错)

(A)当前正在执行指令的前一条指令的地址

(B)当前正在执行指令的地址

(C)当前正在执行指令的下一条指令的地址

(D)控制器中指令寄存器的地址

2.17 通过堆栈操作实现子程序调用,首先就要把(PC)的内容入栈,以进行断点保护。调用返回时,再进行出栈保护,把保护的断点送回到(PC)。

2.18 写出P3口各引脚的第二功能。

答: 口引脚 第二功能定义

单片机原理及应用答案 单片机原理及应用完全参考答案

P3.4 定时器0外部计数输入

P3.5 定时器1外部计数输入

P3.6 外部数据存储器写选通

P3.7 外部数据存储器读选通

2.19 MCS-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单片机正在工作?

第三章 MCS-51的指令系统

3.1 判断以下指令的正误:

答:(3)、(8)、(10)、(11)对,其余错。

3.2 判断下列说法是否正确。

(A)立即寻址方式是被操作的数据本身在指令中,而不是它的地址在指令中。(√)

(B)指令周期是执行一条指令的时间。 (√)

(C)指令中直接给出的操作数称为直接寻址。 (×)

3.3在基址加变址寻址方式中,以(A)作变址寄存器,以(DPTR)或(PC)作基址寄存器

单片机原理及应用答案 单片机原理及应用完全参考答案

3.4 MCS-51共有哪几种寻址方式?各有什么特点?

答: 共有7种寻址方式。[]

(1)寄存器寻址方式 操作数在寄存器中,因此指定了寄存器就能得到操作数。

(2)直接寻址方式 指令中操作数直接以单元地址的形式给出,该单元地址中的内容就是操作数。

(3)寄存器间接寻址方式 寄存器中存放的是操作数的地址,即先从寄存器中找到操作数的地址,再按该地址找到操作数。

(4)立即寻址方式 操作数在指令中直接给出,但需在操作数前面加前缀标志“#”。

(5)基址寄存器加变址寄存器间接寻址方式 以DPTR或PC作基址寄存器,以累加器A作为变址寄存器,并以两者内容相加形成的16位地址作为操作数的地址,以达到访问数据表格的目的。

(6)位寻址方式 位寻址指令中可以直接使用位地址。

(7)相对寻址方式 在相对寻址的转移指令中,给出了地址偏移量,以“rel”表示,即把PC的当前值加上偏移量就构成了程序转移的目的地址。

3.5 MCS-51指令按功能可以分为哪几类?

答:MCS-51指令系统按功能分为:数据传送类(28条);算术操作类(24条);逻辑运算类(25条);控制转移类(17条);位操作类(17条)。

3.6 访问SFR,可使用哪些寻址方式?

答:一般采用直接寻址,对于SFR中字节地址能被8整除的SFR可以使用位寻址,对于SFR中的A、B、DPTR寄存器可以采用寄存器寻址。

3.7 指令格式是由(操作码)和(操作数)所组成,也可能仅由(操作码)组成。

3.8 假定累加器A中的内容为30H,执行指令:

后,把程序存储器(1031H)单元的内容送入累加器中

3.9 在MCS----51中,PC和DPTR都用于提供地址,但PC是为访问(程序)存储器提供地址,而DPTR是为访问(数据)存储器提供地址。

3.10 在寄存器间接寻址方式中,其“间接”体现在指令中寄存器的内容不是操作数,而是操作数的(地址)。

3.11 该程序段的功能是什么?

单片机原理及应用答案 单片机原理及应用完全参考答案

答:功能是A、B内容互换

3.13 写出完成如下要求的指令,但是不能改变未涉及位的内容。

(B)把累加器A的中间4位清0。

后,A的内容为(0CBH)

单片机原理及应用答案 单片机原理及应用完全参考答案

后,SP的内容为(62H),61H单元的内容为(30H),62H单元的内容为(70H)。(]

3.18借助本书中的指令表:表3-3~表3-7对如下的指令代码(16进制)进行手工反汇编。

第四章 MCS-51汇编语言程序设计

4.1 用于程序设计的语言分为哪几种?它们各有什么特点?

答:用于程序设计的语言基本上分为三种:机器语言、汇编语言和高级语言。

(1)机器语言:在单片机中,用二进制代码表示的指令、数字和符号简称为机器语言,直接用机器语言编写的程序称为机器语言程序。用机器语言编写的程序,不易看懂,不便于记忆,且容易出错。(2)汇编语言具有如下特点:A、汇编语言是面向机器的语言,程序设计人员必须对MCS----51单片机的硬件有相当深入的了解。B、助记符指令和机器指令一一对应,所以用汇编语言编写的程序效率高,占用的存储空间小,运行速度快,因此用汇编语言能编写出最优化的程序。C、汇编语言程序能直接管理和控制硬件设备(功能部件),它能处理中断,也能直接访问存储器及I/O接口电路。(3)高级语言:高级语言不受具体机器的限制,都是参照一些数学语言而设计的,使用了许多数学公式和数学计算上的习惯用语,非常擅长于科学计算。计算机不能直接识别和执行高级语言,需要将其“翻译”成机器语言才能识别和执行。

4.3 解释下列术语:“手工汇编”、“机器汇编”、“交叉汇编”以及“反汇编”。

答、手工汇编:通常把人工查表翻译指令的方法称为“手工汇编”。机器汇编:机器汇编实际上是通过执行汇编程序来对源程序进行汇编的。交叉汇编:由于使用微型计算机完成了汇

单片机原理及应用答案 单片机原理及应用完全参考答案

编,而汇编后得到的机器代码却是在另一台计算机(这里是单片机)上运行,称这种机器汇编为“交叉汇编”。[)反汇编:有时,在分析现成产品的ROM/EPROM中的程序时,要将二进制数的机器代码语言程序翻译成汇编语言源程序,该过程称为反汇编。

4.4 下列程序段经汇编后,从1000H开始的各有关存储单元的内容将是什么?

4.5 设计子程序时注意哪些问题?

答:在编写子程序时应注意以下问题:

(1)子程序的第一条指令的地址称为子程序的入口地址。该指令前必须有标号。

(2)主程序调用子程序,是通过主程序或调用程序中的调用指令来实现的。

(3)注意设置堆栈指针和现场保护,因调用子程序时,要把断点压入堆栈,子程序返回执行RET指令时再把断点弹出堆栈送入PC指针,因此子程序结构中必须用堆栈。

(4)子程序返回主程序时,最后一条指令必须是RET指令,它的功能是在执行调用指令时,把自动压入堆栈中的断点地址弹出送入PC指针中,从而实现子程序返回主程序断点处继续执行主程序。

(5)子程序可以嵌套,即主程序可以调用子程序,子程序又可以调用另外的子程序,通常情况下可允许嵌套8层。

(6)在子程序调用时,还要注意参数传递的问题。

4.6 试编写1个程序,将内部RAM中45H单元的高4位清0,低4位置1。

单片机原理及应用答案 单片机原理及应用完全参考答案

4.8 计算下面子程序中指令的偏移量和程序执行的时间(晶振频率为12MHZ)。 7B0F MOV R3,#15 ;1个机器周期

解:程序执行的时间为15.346μs。

后,A的内容为(0CBH)

4.10 试编写程序,查找在内部RAM的30H~50H单元中是否有0AAH这一数据。若有,则将51H单元置为“01H”;若未找到,则将51H单元置为“00H”。

4.11 试编写程序,查找在内部RAM的20H~40H单元中出现“00H”这一数据的次数。并将查找到的结果存入41H单元。

单片机原理及应用答案 单片机原理及应用完全参考答案

4.12 若SP=60H,标号LABEL所在的地址为3456H。[)LCALL指令的地址为2000H,执行如下指令: 2000H LCALL LABEL后,堆栈指针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.6 MCS-51单片机响应外部中断的典型时间是多少?在哪些情况下,CPU将推迟对外部中断请求的响应?

答:典型时间是3-8个机器周期。(]在下列三种情况下,CPU将推迟对外部中断请求的响应:

(1)CPU正在处理同级的或更高级优先级的中断

(2)所查询的机器周期不是当前所正在执行指令的最后一个机器周期

(3)正在执行的指令是RETI或是访问IE或IP的指令。

5.7 中断查询确认后,在下列各种8031单片机运行情况中,能立即进行响应的是(D)

(A)当前正在进行高优先级中断处理

(B)当前正在执行RETI指令

(C)当前指令是DIV指令,且正处于取指令的机器周期

5.8 8031单片机响应中断后,产生长调用指令LCALL,执行指令的过程包括:首先把(PC)的内容压入堆栈,以进行断点保护,然后把长调用指令的16位地址送(PC),使程序执行转向(响应中断请求的中断入口的地址)中的中断地址区。

5.9 编写出外部中断1为跳沿触发的中断初始化程序。

5.10 在MCS-51中,需要外加电路实现中断撤除的是(D)

(B)脉冲方式的外部中断

(D)电平方式的外部中断

5.11 MCS-51有哪几种扩展外部中断源的方法?

答:扩展外部中断源的方法有:定时器/计数器作为外部中断源的使用方法;中断和查询结

单片机原理及应用答案 单片机原理及应用完全参考答案

5.12 下列说法正确的是(C D)

(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。试编写主程序及中断服务程序(转至相应的中断处理程序的入口即可)。

单片机原理及应用答案 单片机原理及应用完全参考答案

第六章 MCS-51的定时器/计数器

6.1 如果采用的晶振的频率为3MHZ,定时器/计数器工作在方式0、1、2下,其最大的定时时间各为多少?

6.2 定时器/计数器用作定时器时,其计数脉冲由谁提供?定时时间与哪些因素有关?

答:定时器/计数器被选定为定时器工作模式时,计数输入信号是内部时钟脉冲,每个机器周期产生1个脉冲使计数器增1,因此,定时器/计数器的输入脉冲的周期与机器周期一样,为时钟振荡频率的1/2。()

6.3 定时器/计数器作计数器使用时,对外界计数频率有何限制?

答:定时器/计数器用作计数器时,计数脉冲来自相应的外部输入引脚T0或T1。对外界计数频率要求为其最高频率为系统振荡频率的1/24。

6.4 采用定时器/计数器T0对外部脉冲进行计数,每计数100个脉冲后,T0转为定时工作方式。定时1ms后,又转为计数方式,如此循环不止。假定MCS---51单片机的晶体震荡器的频率为6MHZ,请使用方式1实现,要求编写出程序。

单片机原理及应用答案 单片机原理及应用完全参考答案

6.5 定时器/计数器的工作方式2有什么特点?适用于哪些应用场合?

答:工作方式2为自动恢复初值的(初值自动装入)8位定时器/计数器,TLX作为常数缓冲器,当TLX计数溢出时,在置1溢出标志TFX的同时,还自动的将THX中的初值送至TLX,使TLX从初值开始重新计数(X=0,1)。(]

6.6 编写程序,要求使用T0,采用方式2定时,在P1。0输出周期为400微秒,占空比为1:10的矩形脉冲。

6.7 一个定时器的定时时间有限,如何实现两个定时器的串行定时,来实现较长时间的定时?

答:第一个定时溢出启动第二个定时计数,实行串行定时

6.8 当定时器T0用于方式3时,应该如何控制定时器T1的启动和关闭?

单片机原理及应用答案 单片机原理及应用完全参考答案

6.9 定时器/计数器测量某正脉冲的宽度,采用何种方式可得到最大量程?若时钟频率为6MHZ,求允许测量的最大脉冲宽度是多少?

答:上升沿从0开始计数,计满回到下降沿。()最大脉冲宽度Tw=131.072us

6.10编写一段程序,功能要求为:当P1.0引脚的电平正跳变时,对P1.1的输入脉冲进行计数;当P1.2引脚的电平负跳变时,停止计数,并将计数值写入R0、R1(高位存R1,低位存R0)。

6.11 THX与TLX(X=0,1)是普通寄存器还是计数器?其内容可以随时用指令更改吗?更改后的新值是立即刷新还是等当前计数器计满之后才能更新?

答:THX与TLX(X=0,1)是计数器,能用指令更改;能立即刷新。

6.12 判断下列说法是否正确?

(1)特殊功能寄存器SCON,与定时器/计数器的控制无关。 (√)

(2)特殊功能寄存器TCON,与定时器/计数器的控制无关 (×)

(3)特殊功能寄存器IE,与定时器/计数器的控制无关 (×)

(4)特殊功能寄存器TMOD,与定时器/计数器的控制无关 (×)

7.3 帧格式为1个起始位,8个数据位和1个停止位的异步串行通信方式是方式(1)。

7.4 串行口有几种工作方式?有几种帧格式?各种工作方式的波特率如何确定?

答:串行口有四种工作方式:方式0、方式1、方式2、方式3

单片机原理及应用答案 单片机原理及应用完全参考答案

7.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通过串行口发送或接收数据时,在程序中应使用:

7.8 为什么定时器/计数器T1用作串行口波特率发生器时,常采用方式2?若已知时钟频率,通讯波特率,如何计算器初值?

答:定时器T1工作方式2是一种自动重装方式,无需在中断服务程序中送数,没有由于中断引起的误差。定时器工作

单片机原理及应用答案 单片机原理及应用完全参考答案

在方式2是一种既省事又精确的产生串行口波特率的方法。(]设定时器T1方式2的初值为X,则有:

7.9 串行口工作方式1的波特率是:(A)固定的,为Fosc/32。

(C)可变得,通过定时器/计数器T1的溢出率设定。

7.10 在串行通讯中,收发双方对波特率的设定应该是的。

7.11 若晶体振荡器为11.0592MHZ,串行口工作于方式1,波特率为4800b/s,写出用T1作为波特率发生器的方式控制字和计数初值。

7.14使用8031的串行口按工作方式3进行串行口数据通讯,假定波特率为1200b/s,第9数据位作奇偶校验位,以中断方式传送数据 ,请编写通讯程序。

单片机原理及应用答案 单片机原理及应用完全参考答案

单片机原理及应用答案 单片机原理及应用完全参考答案

单片机原理及应用答案 单片机原理及应用完全参考答案

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。(]

8.3 假设外部数据存储器2000H单元的内容为80H,执行下列指令后:

累加器A中的内容为(80H)。

8.5 在MCS-51单片机系统中,外接程序存储器和数据存储器共16位地址线和8位数据线,

答:程序存储器和数据存储器虽然公用16位地址线和8位数据线,但由于数据存储器的读和写有/RD(P3.7)和/WR(P3.6)信号控制,而程序存储器有读选通信号/PSEN控制,因此,两者虽然共处同一地址空间,但由于控制信号不同,所以不会发生地址冲突。

8.6 区分MCS-51单片机片外程序存储器和片外数据存储器的最可靠的方法是:4)

1) 看其位于地址范围的低端还是高端

4) 看其时与/RD信号连接还是与/PSEN 信号连接

单片机原理及应用答案 单片机原理及应用完全参考答案

8.7 在存储器扩展中,无论是线选法还是译码法,最终都是为扩展芯片的(片选)端提供的

8.10 在MCS-51中,PC 和DPTR 都用于提供地址,但PC是为访问(程序)存储器提供地址,而DPTR是为访问(数据)存储器

8.11 11根地址线可选(2048)个存储单元,16KB存储单元需要(14)根地址线

(1)确定2864芯片的末地址;

(2)画出2864片选端的地址译码电路;

(3)画出该应用系统的硬件连线图。

9.1 I/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.3 I/O 数据传送有哪几种方式?分别在哪些场合下使用?

答:I/O数据传送的几种方式是:同步传送、异步传送和中断传送

又称为为条件传送。当外设速度可与单片机速度相比拟时,常常采用同步传送方式,最典型的同步传送就是单片机和外部数据存储器之间的数据传送。

又称为与有条件传送,也称为异步传送。单片机通过查询得知外设准备好后,再进行数据传送。异步传送的优点是通用

单片机原理及应用答案 单片机原理及应用完全参考答案

性好,硬件连线和查询程序十分简单,但是效率不高。(]为了提高单片机的工作效率,通常采用中断传送方式

中断传送方式是利用MCS-51本身的中断功能和I./O 接口的中断功能来实现I/O数据的传送。单片机只有在外设准备好后, 发出数据传送请求,才中断主程序,而进入与外设进行数据传送的中断服务程序,进行数据的传送。中断服务完成后又返回主程序继续执行。因此,采用中断方式可以大大提高单片机的工作效率.

9.4编写程序,采用8255A的C口按位置位/复位控制字,将PC7置0,PC4置1,(已知8255A各端口的地址为7FFCH-7FFFH)

9.7 8155H的端口都有哪些?哪些引脚决定端口的地址?引脚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口相应位二极管被点亮的程序。

9.11MCS-51的并行接口的扩展有多种方法,在什么情况下,采用扩展8155H比较合适?什么情况下,采用扩展8255A比较适合?

第十章 MCS-51 与键盘、显示器的接口设计

10.1 为什么要消除按键的机械抖动?消除按键的机械抖动的方法有哪几种?原理是什么? 答: 为了确保CPU对一次按键动作只确认一次按键有效,所

单片机原理及应用答案 单片机原理及应用完全参考答案

以必须消除抖动。(]常采用软件来消除按键抖动,其基本思想是:在第一次检测到有键按下时,该键所对应的行线为低点平,执行一段延时10ms的子程序后,确认该行线电平是否仍为低点平,如果仍为低点平,则确认为该行确实有键按下。当按键松开时,行线的低电平变为高电平,执行一段延时10ms的子程序后,检测该行线为高电平,说明按键确实已经松开。

10.3 LED的静态显示方式与动态显示方式有何区别?各有什么优缺点?

10.5 说明矩阵式键盘按键按下的识别原理

10.7 键盘有哪三种工作方式?它们各自的工作原理及特点是什么?

10.9 根据图10-14的电路,编写在6个LED显示器上轮流显示“1,2,3,4,5,6”的显示程序.

。。。。。。。。 DIR:

第十一章 MCS-51单片机与A/D、D/A转换器的接口

单片机原理及应用答案 单片机原理及应用完全参考答案

11.1 对于电流输出的D/A转换器,为了得到电压的转换结果,应使用(由运算放大器构成的电流/电压转换电路)

11.2 D/A转换器的主要性能指标有哪些?设某DAC为二进制12位,满量程输出电压为5V,试问它的分辨率是多少?

答:D/A转换器的主要性能指标:分辨率、建立时间、精度。[)

11.3 说明DAC用作程控放大器的工作原理 12

答:DAC用作程控放大器的工作原理详见:P283

11.4 使用双缓冲方式的D/A转换器,可以实现多路模拟信号的(同时)输出

11.5 MCS-51 与DAC0832接口时,有哪三种连接方式?各有什么特点?各适合在什么场合使用?

答:单缓冲,双缓冲,直通。单缓冲:两个数据缓冲器有一个处于直通方式,另一个受控锁存锁存方式,应用只有一路输出,或多路,不需求同步。双缓冲:数字量的输入锁存和DAC转换输出分两步完成,适用多路准环的同步输出。直通:所有控制信号均有效,适用于连续反馈控制电路。

11.7 分析A/D转换器产生量化误差的原因,1个8位的A/D转换器,当输入电压为0-5V时,

其最大的量化误差是多少?

答: 量化过程引起的误差.量化误差是由于有限位数字量对模拟量进行量化而引起的误差,提高分辨率可以减少量化误差。△=+LSB/2=+1/2*5/2811.12 判断下列说法是否正确?

1)转换速率这一指标仅适用于A/D转换器,D/A转换器不用考虑转换速率这一问题(F)

2)ADC0809可以利用转换结束信号EOC向8031发出中断请求(T)

3)输出模拟量的最小变化量称为A/D转换器的分辨率(F)

篇二 : 32《单片机应用技术》答案

1. 单片机的含义是什么?其有哪些主要特点? 答:(1)单片机是指将CPU、存储器、定时/计数器、I/O接口电路和必要的外设集成在一块芯片上的微型计算机,其构成一个既小巧又很完善的计算机硬件系统,实现微机的基本功能,早期称其为单片微型计算机SCM,简称单片机。(2)体积小巧、可靠性高、控制功能强、易于扩展、低电压、低功耗、性能价格比优异。

2. 简述单片机程序存储器和数据存储器的区别与类别。 答:

(1)区别:程序存储器用来存放单片机的应用程序及运行中的常数数据,数据存储器用于暂存运行期间的数据、现场采集的原始数据、中间结果、运算结果、缓冲和标志位等临时数据。 (2)程序存储器类别:1)掩膜ROM、2)可编程只读存储器PROM、3)紫外线擦除可编程只读存储器EPROM、4)电擦除可编程E2PROM、5)快闪存储器

(3)数据存储器类别:RAM按器件制造工艺不同分为两类,分别为双极型RAM和MOS型RAM。MOS随机存储器按信息存储的方式又分为静态RAM和动态RAM两种

3. 简述单片机应用系统开发的基本方法。 答:(1)在线仿真开发(2)离线仿真开发(3)ISP开发

5. 将下列十进制数转换为二进制和十六进制数。

6. 机器数、真值、原码、反码和补码如何表示? 答:

(1)在计算机中使用的连同符号位一起数字化的数,称为机器数,机器数所表示的真实值则称为真值。

(2)对有符号数,机器数常用的表示方法有原码、反码、补码三种。1)原码最高位为符号位,“0”表示正,“1”表示负,其余位表示数值的大小;2)反码规定正数的反码与其原码相同;负数的反码是对其原码逐位取反,但符号位除外。3)正数的补码与其原码相同;负数的补码是在其反码的末位加1。

7. 设计器字长为8位,求下列数值的二、十六进制原码、反码和补码。 (1)+0 (2)-0 (3)+33 (4)-33 (5)-127 答:

8. 把下列数看成无符号数时,对应的十进制数为多少?若把其看成有符号数的补码,对应的十进制数是多少?

(1) B (2)B 答:看做无符号数时:(1)161(2)128;看做有符号数时:(1)-33(2)-127

9. 若要访问片外32KB的存储空间,假设每个存储单元是一个字节,计算需要多少根地址线。 答:15根。

10. MCS-51型单片机由哪些单元组成?各自的功能是什么? 答:

(1)8位的CPU CPU是89C51单片机的核心,完成运算和控制功能,一次能处理8位二进制数或代码;

(2)256B的内部RAM 内部RAM能作为寄存器供用户使用的只是前128个单元,用于存放可读写的临时数据,其中后128个单元被专用寄存器占用;

(3)4KB的内部Flash ROM 简称内部ROM,存放程序、原始数据或表格数据; (4)2个16位的定时/计数器T0/T1 89C51共有2个16位的定时/计数器,以实现定时或计数功能,并以其定时或计数结果对计算机进行控制;

(5)4个8位并行I/O口 分别为P0、P1、P2、P3,实现数据的并行输入输出; (6)1个全双工的串行口 实现单片机和其他设备之间的串行数据传送;

(7)5个中断源 包括2个外部中断,2个定时/计数中断,1个串行口发送/接收中断; (8)片内时钟振荡电路 89C51芯片允许的晶振频率一般为1~24MHz。

11. MCS-51型单片机控制线有几根?每一根控制线的作用是什么? 答:控制线有4条,功能如下:

(1)ALE/PROG 地址锁存控制信号。 (2)PSEN 外部程序存储器读选通信号。 (3)EA/Vpp 访问程序存储控制信号。 (4)RST/Vpd RST是复位信号输入端

12. 何为单片机最小应用系统?

答:单片机最小应用系统是指能使单片机独立工作运行的尽可能少的电路连接。

13. 时钟电路的作用是什么?

答:时钟电路用于产生单片机工作所需要的时钟信号,唯一的时钟信号控制下的时序可以保证单片机各部件的同步工作。

89C51的并行I/O口为单片机与外部器件或设备进行信息交换提供了多功能的输入/输出通道,是单片机扩展外部功能、构成单片机应用系统的重要物理基础。

4个I/O口都具有字节寻址和位寻址功能,每一位均可作为双向的通用I/O功能使用,具体如下:

(1)P0口为双功能8位并行I/O口。可作通用数据I/O端口使用;在访问片外扩展的存储器时,又可作地址/数据总线分时传输低8位地址和8位数据。

(2)P1口为单一功能的并行I/O口,只用作通用的数据I/O端口。

(3)P2口为双功能8位并行I/O口。可作通用数据I/O端口使用,又可在访问片外扩展的存储器时用作高8位地址总线。

(4)P3口为双功能8位并行I/O口,第一功能是通用数据I/O端口,还有第二功能。

15. P3口的第二功能是什么? 答:

16. 编写程序实现监视开关K1,如果开关K1合上,L1灭,开关K1打开,L1亮。 答:

17、MCS-51型单片机片内RAM的组成是如何划分的,各有什么功能? 答:(1)00H~1FH为工作寄存器组区,共分4组,每组占用8个RAM字节单元,每个单元作为一个工作寄存器,每组的8个单元分别定义为8个工作寄存器R0~R7。

(2)20H~2FH为可位寻址区域,这16个字节的每一位都有一个地址,编址为00H~7FH。 位寻址区也可以用作字节寻址的一般数据缓冲区使用。

(3)30H~7FH为堆栈、数据缓冲区。

18. MCS89C51 单片机有多少个特殊功能寄存器?其分布在何地址范围?

答:DPTR是16位数据指针寄存器,它由两个8位特殊功能寄存器DPL(数据指针低8位)和DPH(数据指针高8位)组成,DPTR用于保存16位地址,作间址寄存器用,可寻址外部数据存储器,也可寻址程序存储器。

19. DPTR是什么寄存器?其作用是什么?其是由哪几个寄存器组成?

答:DPTR是16位数据指针寄存器,它由两个8位特殊功能寄存器DPL(数据指针低8位)和DPH(数据指针高8位)组成,DPTR用于保存16位地址,作间址寄存器用,可寻址外部数据存储器,也可寻址程序存储器。

20. 程序状态字寄存器PSW的作用是什么?常用状态有哪些位?作用是什么?

PSW是一个8位特殊功能寄存器,用于存放程序的状态和指令的执行状态,供程序查询和判别用。PSW

CY:进位标志位。在执行加、减法指令时,如果运算结果的最高位(D7位)有进位或借位,CY位被置“1”,否则清“0”。

AC:半进位标志位。在执行加、减法指令时,其低半字节向高半字节有进位或借位时(D3位向D4位),AC位被置“1”,否则清“0”。AC位主要被用于BCD码加法调整,详见DA指令。 F0:用户自定义标志位。用户根据自己的需要对F0赋以一定含义,由用户置位、复位,作为软件标志。

RS1和RS0:工作寄存器组选择位。它们的0、1组合状态用来确定当前工作寄存器组,前已详述。 OV:溢出标志位。在补码运算,当运算结果超出-128~+127的范围时(溢出),OV位被置“1”,无溢出,OV位为“0”。

P:奇偶校验标志位。每条指令执行完毕,A中有奇数个1,则P=1,否则P=0。该标志位用在串行通信中,常用奇偶校验的方法检验数据传输的可靠性。

21. 什么是堆栈?堆栈指示器SP的作用是什么?在堆栈中存取数据时的原则是什么? 答:

(1)堆栈是一个特殊的存储区,设在内部RAM中,用来暂存数据和地址,按“先进后出”的原则存取数据。堆栈有入栈和出栈两种操作,用SP作为堆栈指针。

(2)系统复位后SP的内容为07H,使得堆栈实际上从08H单元开始。如果需要改变,用户可以通过指令在00H-7FH中任意选择。但08H~1FH单元分别属于工作寄存器1~3区,如程序中要用到这些区,则最好把SP值改为1FH或更大的值,堆栈最好在内部RAM的30H~7FH单元中开辟。SP的内容一经确定,堆栈的底部位置即确定,由于SP可用指令初始化为不同值,因此堆栈底部位置是不确定的,栈顶最大可为7FH单元。

空间中,0003H~002BH有什么用途?用户应怎样合理安排? 答:0003H~002AH,共40个单元,这40个单元被均匀地分为五段,作为五个中断源的中断地址区。程序存储器特殊功能存储单元如下表所示。

23. P0~P3口作为输入口时,有何要求? 答:4个端口都称为“准双向口”,不是真正的双向口,必须将位锁存器置“1”后,才可以读入正确信息。

24. 画出MCS-51型单片机时钟电路,并指出石英晶体和电容的取值范围。 答:一般电容C1和C2取30pF左右,晶体振荡频率范围是1.2MHz~24MHz。

a)内部时钟 b)外部时钟

25. 什么是机器周期?机器周期和时钟频率有何关系?当时钟频率为6 MHz时,机器周期是多少时间?

答:单片机晶振芯片每秒振荡的次数称为时钟频率,振荡一次所需时间称为振荡周期。12个振荡周期是一个机器周期。时钟频率为6 MHz时,机器周期是2μs。

26. MCS-51型单片机常用的复位方法有几种?画出电路图。

答:单片机常见的复位电路包括上电复位电路和按键复位电路。如下图所示。

a)上电复位电路 b)按键复位电路

27. MCS-51单片机的指令有哪些寻址方式?

答:(1)立即寻址 (2)直接寻址 (3)寄存器寻址 (4)寄存器间接寻址 (5)基址+变址间接寻址 (6)相对寻址(7)位寻址

28 分析下面指令中源操作数的寻址方式。

32《单片机应用技术》答案_单片机应用

29. MCS-51单片机指令系统按功能分哪为几类?

30. 在“MOVC A,@A+DPTR”和“MOVC A,@A+PC”中,分别使用了DPTR和PC作基址,请问这两个基址代表什么地址?使用中有何不同?

使用@A+DPTR基址变址寻址时,DPTR为常数且是表格的首地址,A为从表格首址到被访问字节地址的偏移量。使用@A+PC基址变址寻址时,PC仍是下条指令首地址,而A则是从下条指令首地址到常数表格中的被访问字节的偏移量。

31. 用指令实现以下数据传送过程。

(1)R1的内容送R0

(2)片内RAM20H单元的内容送R1

(3)片外RAM20H单元的内容送片内20H单元

(5)程序存储器2000H单元的内容送R0

(6)程序存储器2000H单元的内容送片内RAM20H单元

(7)程序存储器2000H单元的内容送片外RAM20H单元

(1)R1的内容送R0

(2)片内RAM20H单元的内容送R1

(3)片外RAM20H单元的内容送片内20H单元

(5)程序存储器2000H单元的内容送R0。

(6)程序存储器2000H单元的内容送片内RAM20H单元。

(7)程序存储器2000H单元的内容送片外RAM20H单元。

32. 用直接地址寻址方式、寄存器间接寻址方式、字节交换法和堆栈传递法等4种方法将内部RAM30H与31H单元的数据交换。

33. 片内RAM 20H~2FH单元中的128个位地址与直接地址00H~7FH形式完全相同,如何在指令中区分出位寻址操作和直接寻址操作?

虽然内部RAM位寻址区的位地址范围00H~7FH与低128个单元的单元地址范围00H~7FH

形式完全相同,但是在应用中可以通过指令的类型区分单元地址和位地址。

位寻址的操作只适用于下列位指令,而直接寻址操作对这些指令是无效的。

34 编写一段程序,将片内RAM30H单元的内容与片外RAM30H单元的数据交换。

36. 说明无条件转移指令AJMP、SJMP、LJMP和JMP的功能和应用场合。

AJMP为2KB地址范围内的的转移指令;

SJMP为相对转移指令,本指令首地址加上偏移量加上2为跳转到的位置;

LJMP为64KB程序存储空间的全范围转移指令,转移的地址可为16位地址中的任意值; JMP 间接转移指令。

38. 编制一程序,查找内部RAM20~2FH单元中是否有数据0AAH。若有,则将30H单元置为01H,否则将30H单元清0。

39. 片内RAM40H开始的单元内有10个二进制数,编程找出其中最大值并存于50H单元中. 答:

40. 编制一个循环闪烁灯的程序,画出电路图。在P0口接有8个发光二极管,要求每次其中某

个灯闪烁点亮10次后,转到下一个闪烁10次,循环不止。

41. 编程实现如下操作,不得改变未涉及到的位的内容。

(1)使累加器A的最高位置“1” (2)对累加器A高4位取反

42. 单项选择题,从四个备选项中选择正确的选择。

(1)89C51汇编语言指令格式中,唯一不可缺少的部分是 。

A.标号 B.操作码 C.操作数 D.注释

(2)89C51的立即寻址方式中,立即数前面 。

A.应加前缀“/:”号 B.不加前缀号 C.应加前缀“@”号 D.应加前缀“#”号

(3)下列完成89C51单片机内部数据传送的指令是 。

(4)89C51的立即寻址的指令中,立即数就是 。

A.放在寄存器R0中的内容 B.放在程序中的常数 C.放在A中的内容

(5)单片机中PUSH和POP指令常用来 。

A.保护断点 B.保护现场 C.保护现场,恢复现场 D.保护断点,恢复断点

(6)89C51寻址方式中,操作数Ri加前缀“@”号的寻址方式是 。

A.寄存器间接寻址 B.寄存器寻址 C.基址加变址寻址 D.立即寻址

32《单片机应用技术》答案_单片机应用

A.C.高电平,高电平,高电平 B.低电平 D.低电平,低电平,高电平 低电平

(8)下列指令判断若P1口最低位为高电平就转LP,否则就执行下一句的是 。

(9)下列指令中比较转移指令是指 。

(11)执行如下三条指令后,30H单元的内容是 。

A.P0口送高8位,P1口送高8位 B.P0口送低8位,P2口送高8位

C.P0口送低8位,P1口送低8位 D.P0口送高8位,P1口送低8位

(13)在89C51指令中,下列指令中 是无条件转移指令。

(15)将内部数据存储单元的内容传送到累加器A中的指令是 。

(16)下列指令执行时,修改PC中内容的指令是 。

(19)89C51指令系统中,清0指令是 。

(21)下列指令能能使累加器A低4位不变,高4位置F的是 。

(22)下列指令判断若P1口的最低位为低电平就转LP,否则就执行下一句的是 。

(23)89C51指令系统中,指令DA A应跟在 。

A.加法指令后 B.BCD码的加法指令后

C.减法指令后 D.BCD码的减法指令后

(24)执行下列程序后,累加器A的内容为 。

43. 何为伪指令?其作用是什么?

答:伪指令不属于指令集之中的指令,但具有和指令类似的形式,其作用是对汇编过程进行某种控制或提供某些汇编信息,不产生可执行的目标代码。

44. 什么是中断?单片机采用中断有什么好处?

在单片机中,当CPU在执行程序时,由单片机内部或外部的原因引起的随机事件要求CPU暂时停止正在执行的程序,而转向执行一个用于处理该随机事件的程序,处理完后又返回被中止的程序断点处继续执行,这一过程称为中断。

单片机在某一时刻只能处理一个任务,当多个任务同时要求单片机处理时,由于资源有限,因此就可能出现资源竞争的局面,即几项任务来争夺一个CPU。而中断技术就是解决资源竞争的有效方法,采用中断技术可以使多项任务共享一个资源。

45. T0用做定时器,以方式0工作,定时10ms,单片机晶振频率为6MHZ,请计算定时初值。 答:

46. 单项选择题,从四个备选项中选择正确的选择。

(1)89C51单片机的定时器T1用作定时方式时是 。

A.由内部时钟频率定时,一个时钟周期加1

B.由内部时钟频率定时,一个机器周期加 1

C.由外部时钟频率定时,一个时钟周期加1

D.由外部时钟频率定时,一个机器周期加1

(2)89C51单片机的定时器T0用作计数方式时是 。

A.由内部时钟频率定时,一个时钟周期加1

B.由内部时钟频率定时,一个机器周期加1

C.由外部计数脉冲计数,下降沿加1

D.由外部计数脉冲计数,一个机器周期加1

(3)89C51单片机的定时器T1用作计数方式时计数脉冲是 。

A.外部计数脉冲由T1(P3.5)输入 B.外部计数脉冲由内部时钟频率提供

C.外部计数脉冲由T0(P3.4)输入 D.由外部计数脉冲计数

(5)用89C51的定时器T1作定时方式,用模式1,则初始化编程为 。

(6)用89C51的定时器,若用软启动,应使TOMD中的 。

(7)启动定时器1开始定时的指令是 。

(8)使89C51的定时器T0停止计数的指令是 。

(9)下列指令判断若定时器T0计满数就转LP的是 。

(10)下列指令判断若定时器T0未计满数就原地等待的是 。

(11)当CPU响应定时器T1的中断请求后,程序计数器PC的内容是 。

(12)当CPU响应外部中断0的中断请求后,程序计数器PC的内容是 。

(13)89C51单片机在同一级别里除串行口外,级别最低的中断源是 。

A.外部中断1 B.定时器T 0 C.定时器T1 D.串行口

(14)当外部中断0发出中断请求后,中断响应的条件是 。

(15)当定时器T0发出中断请求后,中断响应的条件是 。

(16)用定时器T1方式1计数,要求每计满10次产生溢出标志,则TH1、TL1的初始值是 。

(17)89C51单片机的TMOD用于控制T1和T0的操作模式及工作方式,其中C/T表示的是 。

A.门控位 B.操作模式控制位 C.功能选择位 D.启动位

(18)89C51单片机定时器T1的溢出标志TF1,若计满数产生溢出时,如不用中断方式而用查询方式,则应 。

A.由硬件清零 B.由软件清零 C.由软件置于 D.可不处理

(19)89C51当串行口接收或发送完一帧数据时,将SCON中的 ,向CPU申请中断。

(20)执行中断处理程序最后一句指令RETI后, 。

A.程序返回到ACALL的下一句 B.程序返回到LCALL的下一句

C.程序返回到主程序开始处 D.程序返回到响应中断时一句的下一句

47. 说明LED的静态显示和动态显示的区别是什么?

静态显示:为固定显示方式,无闪烁,一个并行口接一个数码管,数码管的公共端按共阴或共阳分别接地或VCC。

动态显示:为各数码管轮流显示,当循环显示的频率较高时,利用人眼的暂留特性,看不出闪烁现象,这种显示方式一个接口完成字形码的输出,另一个接口完成各数码管的轮流点亮。

48. A/D转换和D/A转换的区别是什么?为何要进行转换?

答:A/D转换器是一种用来将连续的模拟信号转换成二进制数的器件,D/A转换器是一种将数字信号转换成模拟信号的器件,为计算机系统的数字信号和模拟环境的连续信号之间提供了一种接口。

(1)89C51单片机执行MOVX指令时,P0口作为地址线,专用于输出存储器的高8位地址;P2口专用于输出存储器的低8位地址。( )

(2)线选法是把单根的低位地址线直接接到存储器芯片的片选端。( )

(3)对于8031单片机而言,在外部扩展EPROM时,EA引脚应接地。( )

(4)对于89C51单片机而言,在外部扩展EPROM时,EA引脚可接+5V或接地。

(5)8155芯片的地址/数据线AD0~AD7是低8位地址和数据复用线引脚,当ALE=1时,输入的是数据信息,否则是地址信息。( )

(6)在接口芯片中,通常都有一个片选端CS(或CE),作用是当CS为低电平时该芯片才能进行读写操作。( )

(7)DAC0832是8位的D/A转换器,其输出量为数字电流量。( )

(10)DAC0832的片选信号输入线CS是低电平有效。( )

50. 简述单片机应用系统设计的一般流程。

答:总体设计、硬件设计、资源分配、软件设计、软件仿真。

51. 简述硬件设计的任务是什么?

答:硬件设计的任务是根据总体设计要求,在所选择机型的基础上,确定系统扩展所需的存储器、I/O电路、A/D电路以及有关外围电路等,然后设计出系统的电路原理图。

篇三 : 单片机原理及应用完全参考答案

1.2 除了单片机这一名称之外,单片机还可称为(微控制器)和(嵌入式控制器)。

1.3 单片机与普通计算机的不同之处在于其将(微处理器)、(存储器)和(各种输入输出接口)三部分集成于一块芯片上。

4、单片机的发展大致分为哪几个阶段?

答:单片机的发展历史可分为四个阶段:

第一阶段(1974年----1976年):单片机初级阶段。

第二阶段(1976年----1978年):低性能单片机阶段。

第三阶段(1978年----现在):高性能单片机阶段。

第四阶段(1982年----现在):8位单片机巩固发展及16位单片机、32位单片机推出阶段

1.5 单片机根据其基本操作处理的位数可分为哪几种类型?

答:单片机根据其基本操作处理的位数可分为:1位单片机、4位单片机、8位单片机、16位单片机和32位单片机。

1.6 MCS-51系列单片机的基本芯片分别为哪几种?它们的差别是什么? 答:基本芯片为8031、8051、8751。

8031内部包括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.7 MCS-51系列单片机与80C51系列单片机的异同点是什么?

答:共同点为它们的指令系统相互兼容。不同点在于MCS-51是基本型,而80C51采用CMOS工艺,功耗很低,有两种掉电工作方式,一种是CPU停止工作,其它部分仍继续工作;另一种是,除片内RAM继续保持数据外,其它部分都停止工作。

(A)内部数据存储单元数目的不同 (B)内部数据存储器的类型不同

(C)内部程序存储器的类型不同 (D)内部的寄存器的数目不同

1.9 在家用电器中使用单片机应属于微型计算机的(B)

(A)辅助设计应用 (B)测量、控制应用 (C)数值计算应用 (D)数据处理应用

1.10 说明单片机主要应用在哪些领域?

答:单片机主要运用领域为:工业自动化;智能仪器仪表;消费类电子产品;通信方面;武器装备;终端及外部设备控制;多机分布式系统。

第二章 MCS-51单片机的硬件结构

2.1 MCS-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.3 MCS-51的时钟振荡周期和机器周期之间有何关系?

答:每12个时钟周期为1个机器周期。

2.4在MCS-51 单片机中,如果采用6 MHZ 晶振,1个机器周期为(2微秒)。

2.5程序存储器的空间里,有5个单元是特殊的,这5个单元对应MCS-51单片机5个中断源的中断入口地址,请写出这些单元的地址以及对应的中断源。

答: 中断源 入口地址

2.6 内部RAM中,位地址为30H的位,该位所在字节的字节地址为(26H)。

2.7 若A中的内容为63H,那么,P标志位的值为(0)。

2.8 判断下列说法是否正确:

(B)区分片外程序存储器和片外数据存储器的最可靠的方法是看其位于地址范围的低端还是高端。 (错)

(C)在MCS-51中,为使准双向的I/O口工作在输入方式,必须保证它被事先预置为1。 (对)

(D)PC可以看成是程序存储器的地址指针。 (对)

2.9 8031单片机复位后,R4所对应的存储单元的地址为(04H),因上电时PSW=(00H)。这时当前的工作寄存器区是(0)组工作寄存器区。

2.10 什么是机器周期?1个机器周期的时序是如何来划分的?如果采用12MHZ晶振,1个机器周期为多长时间?

答:CPU完成一个基本操作所需要的时间称为机器周期。时序划分:一个机器周期包括12个时钟周期,分为6个状态;S1-S6。每个状态又分为2拍;P1和P2。因此,1个机器周期中的12个时钟周期表示为:S1P1、S1P2、S2P1、S2P2、?、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中的RS1、RS0来切换当前的工作寄存器区,这种功能给软件设计带来极大的方便,特别是在中断嵌套时,为实现工作寄存器现场内容保护提供了方便;字节地址为20H-2FH的16个单元可进行工128位的位寻址,这些单元构成了1位处理机的存储器空间;字节地址为30H-7FH的单元为用户RAM区,只能进行字节寻址。用于作为数据缓冲区以及堆栈区。

2.15 判断下列说法是否正确

(A)程序计数器PC不能为用户编程时直接使用,因为它没有地址。 (对)

(B)内部RAM的位寻址区,只能供位寻址使用,而不能供字节寻址使用。 (错)

(C)8031共有21个特殊功能寄存器,它们的位都是可用软件设置的,因此,是可以进行位寻址的。 (错)

(A)当前正在执行指令的前一条指令的地址

(B)当前正在执行指令的地址

(C)当前正在执行指令的下一条指令的地址

(D)控制器中指令寄存器的地址

2.17 通过堆栈操作实现子程序调用,首先就要把(PC)的内容入栈,以进行断点保护。调用返回时,再进行出栈保护,把保护的断点送回到(PC)。

2.18 写出P3口各引脚的第二功能。

答: 口引脚 第二功能定义

P3.4 定时器0外部计数输入

P3.5 定时器1外部计数输入

P3.6 外部数据存储器写选通

P3.7 外部数据存储器读选通

2.19 MCS-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单片机正在工作?

第三章 MCS-51的指令系统

3.1 判断以下指令的正误:

答:(3)、(8)、(10)、(11)对,其余错。

3.2 判断下列说法是否正确。

(A)立即寻址方式是被操作的数据本身在指令中,而不是它的地址在指令中。(√)

(B)指令周期是执行一条指令的时间。 (√)

(C)指令中直接给出的操作数称为直接寻址。 (×)

3.3在基址加变址寻址方式中,以(A)作变址寄存器,以(DPTR)或(PC)作基址寄存器

3.4 MCS-51共有哪几种寻址方式?各有什么特点?

答: 共有7种寻址方式。

(1)寄存器寻址方式 操作数在寄存器中,因此指定了寄存器就能得到操作数。

(2)直接寻址方式 指令中操作数直接以单元地址的形式给出,该单元地址中的内容就是操作数。

(3)寄存器间接寻址方式 寄存器中存放的是操作数的地址,即先从寄存器中找到操作数的地址,再按该地址找到操作数。

(4)立即寻址方式 操作数在指令中直接给出,但需在操作数前面加前缀标志“#”。

(5)基址寄存器加变址寄存器间接寻址方式 以DPTR或PC作基址寄存器,以累加器A作为变址寄存器,并以两者内容相加形成的16位地址作为操作数的地址,以达到访问数据表格的目的。

(6)位寻址方式 位寻址指令中可以直接使用位地址。

(7)相对寻址方式 在相对寻址的转移指令中,给出了地址偏移量,以“rel”表示,即把PC的当前值加上偏移量就构成了程序转移的目的地址。

3.5 MCS-51指令按功能可以分为哪几类?

答:MCS-51指令系统按功能分为:数据传送类(28条);算术操作类(24条);逻辑运算类(25条);控制转移类(17条);位操作类(17条)。

3.6 访问SFR,可使用哪些寻址方式?

答:一般采用直接寻址,对于SFR中字节地址能被8整除的SFR可以使用位寻址,对于SFR中的A、B、DPTR寄存器可以采用寄存器寻址。

3.7 指令格式是由(操作码)和(操作数)所组成,也可能仅由(操作码)组成。

3.8 假定累加器A中的内容为30H,执行指令:

后,把程序存储器(1031H)单元的内容送入累加器中

3.9 在MCS----51中,PC和DPTR都用于提供地址,但PC是为访问(程序)存储器提供地址,而DPTR是为访问(数据)存储器提供地址。

3.10 在寄存器间接寻址方式中,其“间接”体现在指令中寄存器的内容不是操作数,而是操作数的(地址)。

3.11 该程序段的功能是什么?

答:功能是A、B内容互换

3.13 写出完成如下要求的指令,但是不能改变未涉及位的内容。

(B)把累加器A的中间4位清0。

后,A的内容为(0CBH)

后,SP的内容为(62H),61H单元的内容为(30H),62H单元的内容为(70H)。

3.18借助本书中的指令表:表3-3~表3-7对如下的指令代码(16进制)进行手工反汇编。

第四章 MCS-51汇编语言程序设计

4.1 用于程序设计的语言分为哪几种?它们各有什么特点?

答:用于程序设计的语言基本上分为三种:机器语言、汇编语言和高级语言。

(1)机器语言:在单片机中,用二进制代码表示的指令、数字和符号简称为机器语言,直接用机器语言编写的程序称为机器语言程序。用机器语言编写的程序,不易看懂,不便于记忆,且容易出错。(2)汇编语言具有如下特点:A、汇编语言是面向机器的语言,程序设计人员必须对MCS----51单片机的硬件有相当深入的了解。B、助记符指令和机器指令一一对应,所以用汇编语言编写的程序效率高,占用的存储空间小,运行速度快,因此用汇编语言能编写出最优化的程序。C、汇编语言程序能直接管理和控制硬件设备(功能部件),它能处理中断,也能直接访问存储器及I/O接口电路。(3)高级语言:高级语言不受具体机器的限制,都是参照一些数学语言而设计的,使用了许多数学公式和数学计算上的习惯用语,非常擅长于科学计算。计算机不能直接识别和执行高级语言,需要将其“翻译”成机器语言才能识别和执行。

4.3 解释下列术语:“手工汇编”、“机器汇编”、“交叉汇编”以及“反汇编”。

答、手工汇编:通常把人工查表翻译指令的方法称为“手工汇编”。机器汇编:机器汇编实际上是通过执行汇编程序来对源程序进行汇编的。交叉汇编:由于使用微型计算机完成了汇

编,而汇编后得到的机器代码却是在另一台计算机(这里是单片机)上运行,称这种机器汇编为“交叉汇编”。反汇编:有时,在分析现成产品的ROM/EPROM中的程序时,要将二进制数的机器代码语言程序翻译成汇编语言源程序,该过程称为反汇编。

4.4 下列程序段经汇编后,从1000H开始的各有关存储单元的内容将是什么?

4.5 设计子程序时注意哪些问题?

答:在编写子程序时应注意以下问题:

(1)子程序的第一条指令的地址称为子程序的入口地址。该指令前必须有标号。

(2)主程序调用子程序,是通过主程序或调用程序中的调用指令来实现的。

(3)注意设置堆栈指针和现场保护,因调用子程序时,要把断点压入堆栈,子程序返回执行RET指令时再把断点弹出堆栈送入PC指针,因此子程序结构中必须用堆栈。

(4)子程序返回主程序时,最后一条指令必须是RET指令,它的功能是在执行调用指令时,把自动压入堆栈中的断点地址弹出送入PC指针中,从而实现子程序返回主程序断点处继续执行主程序。

(5)子程序可以嵌套,即主程序可以调用子程序,子程序又可以调用另外的子程序,通常情况下可允许嵌套8层。

(6)在子程序调用时,还要注意参数传递的问题。

4.6 试编写1个程序,将内部RAM中45H单元的高4位清0,低4位置1。

4.8 计算下面子程序中指令的偏移量和程序执行的时间(晶振频率为12MHZ)。 7B0F MOV R3,#15 ;1个机器周期

解:程序执行的时间为15.346μs。

后,A的内容为(0CBH)

4.10 试编写程序,查找在内部RAM的30H~50H单元中是否有0AAH这一数据。若有,则将51H单元置为“01H”;若未找到,则将51H单元置为“00H”。

4.11 试编写程序,查找在内部RAM的20H~40H单元中出现“00H”这一数据的次数。并将查找到的结果存入41H单元。

4.12 若SP=60H,标号LABEL所在的地址为3456H。LCALL指令的地址为2000H,执行如下指令: 2000H LCALL LABEL后,堆栈指针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.6 MCS-51单片机响应外部中断的典型时间是多少?在哪些情况下,CPU将推迟对外部中断请求的响应?

答:典型时间是3-8个机器周期。在下列三种情况下,CPU将推迟对外部中断请求的响应:

(1)CPU正在处理同级的或更高级优先级的中断

(2)所查询的机器周期不是当前所正在执行指令的最后一个机器周期

(3)正在执行的指令是RETI或是访问IE或IP的指令。

5.7 中断查询确认后,在下列各种8031单片机运行情况中,能立即进行响应的是(D)

(A)当前正在进行高优先级中断处理

(B)当前正在执行RETI指令

(C)当前指令是DIV指令,且正处于取指令的机器周期

5.8 8031单片机响应中断后,产生长调用指令LCALL,执行指令的过程包括:首先把(PC)的内容压入堆栈,以进行断点保护,然后把长调用指令的16位地址送(PC),使程序执行转向(响应中断请求的中断入口的地址)中的中断地址区。

5.9 编写出外部中断1为跳沿触发的中断初始化程序。

5.10 在MCS-51中,需要外加电路实现中断撤除的是(D)

(B)脉冲方式的外部中断

(D)电平方式的外部中断

5.11 MCS-51有哪几种扩展外部中断源的方法?

答:扩展外部中断源的方法有:定时器/计数器作为外部中断源的使用方法;中断和查询结

5.12 下列说法正确的是(C D)

(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。试编写主程序及中断服务程序(转至相应的中断处理程序的入口即可)。

第六章 MCS-51的定时器/计数器

6.1 如果采用的晶振的频率为3MHZ,定时器/计数器工作在方式0、1、2下,其最大的定时时间各为多少?

6.2 定时器/计数器用作定时器时,其计数脉冲由谁提供?定时时

我要回帖

更多关于 单片机定时器 的文章

 

随机推荐