单片机课后习题答案[1]1

2018-12-06 21:17

习题 3

1.结合MCS-51系列单片机功能框图阐明其大致组成。 答: MCS-51系列单片机内部组成如图所示。

主要有 8031、8051、875l 三种机型,基于 HMOS 工艺,它们的指令系统与芯片引脚完 全兼容,只是片内程序存储器(ROM, Read Only Memory)有所不同。 51子系列的主要功能为: ● 8位CPU;

● 片内带振荡器及时钟电路; ● 128B片内数据存储器;

● 4KB片内程序存储器(8031/80C31无) ; ● 程序存储器的寻址范围为64KB; ● 片外数据存储器的寻址范围为64KB; ● 21B特殊功能寄存器; ● 4×8根I/O线;

● 1个全双工串行I/O接口,可多机通信; ● 两个16位定时器/计数器;

● 中断系统有5个中断源,可编程为两个优先级; ● 111条指令,含乘法指令和除法指令; ● 布尔处理器; ● 使用单+5V电源。

2.综述80C51系列单片机各引脚的作用。 答: 80C51 有 4 个 8 位并行 I/O 口,共 32 条端线: P0、P1、P2 和 P3 口。每一个 I/O 口都能用作输入或输出。

用作输入时,均须先写入“1” ;用作输出时,P0口应外接上拉电阻。

P0口的负载能力为8个LSTTL门电路; P1~P3口的负载能力为4个LSTTL门电路。 在并行扩展外存储器或I/O口情况下:

P0口用于低8位地址总线和数据总线(分时传送) P2口用于高8位地址总线, P3口常用于第二功能,

用户能使用的I/O口只有P1口和未用作第二功能的部分P3口端线。 3.80C51单片机内部包含哪些主要逻辑功能部件?各有什么主要功能?

答: 80C51 单片机内部包含含布尔(位)处理器的中央处理器、数据存储器和程序、并行输入/输出端口、中断系统、定时器/计数器,串行口、时钟电路、复位电路。 4.什么是ALU?简述MCS-51系列单片机ALU的功能与特点。

答: ALU是用于对数据进行算术运算和逻辑操作的执行部件,由加法器和其他逻辑电路(移位电路和判断电路等)组成。在控制信号的作用下,它能完成算术加、减、乘、除和逻辑与、或、异或等运算以及循环移位操作、位操作等功能。

5.如何认识:80C51存储器空间在物理结构上可划分为4个空间,而在逻辑上又可划分 为3个空间?

答:而 80C51 在物理结构上有 4 个存储空间:片内程序存储器、片外程序存储器、片内数据存储器和片外数据存储器。但在逻辑上,即从用户使用的角度上,80C51 有三个存储空间:片内外统一编址的64KB程序存储器地址空间(用16位地址) 、256 B片内数据存储器的地址空间(用8位地址)及64KB片外数据存储器地址空间(用16位地址)。在访问

三个不同的逻辑空间时,应采用不同形式的指令(见指令系统),以产生不同的存储空间的选通信号。

6.什么是指令?什么是程序?简述程序在计算机中的执行过程。

答:指令由操作码和操作数构成,分别表示何种操作和操作数的存储地址; 而程序则是:程序是可以连续执行,并能够完成一定任务的一条条指令的集合。

程序执行是由控制器控制的,控制器是CPU的大脑中枢,它包括定时控制逻辑、指令寄 存器IR、数据指针DPTR及程序计数器PC、堆栈指针SP、地址寄存器、地址缓冲器等。它的功能是对程序的逐条指令进行译码,并通过定时和控制电路在规定的时刻发出各种操作所需的内部和外部控制信号,协调各部分的工作,完成指令规定的操作。 7. 什么是堆栈?堆栈有何作用?在程序设计时,有时为什么要对堆栈指针SP重新赋值? 如果CPU在操作中要使用两组工作寄存器,你认为SP的初值应为多大? 答: 堆栈是个特殊的存储区,主要功能是暂时存放数据和地址,通常用来保护断点和现场。 它的特点是按照先进后出的原则存取数据,这里的进与出是指进栈与出栈操作。

80C51片内RAM的部分单元可以用做堆栈。有一个8位的堆栈指针寄存器SP,专用于 指出当前堆栈顶部是片内RAM的哪一个单元。80C51单片机系统复位后SP的初值为07H, 也就是将从内部 RAM 的 08H 单元开始堆放信息。但是,80C51 系列的栈区不是固定的,只要通过软件改变 SP寄存器的值便可更动栈区。为了避开工作寄存器区和位寻址区,SP 的初值可置为2FH或更大的地址值。

如果CPU在操作中要使用两组工作寄存器,如果不使用位变量, SP的初值至少应为0FH 或更大的值;如果使用位变量,SP 的初值至少应为 2FH 或更大的值;Keil C51 编译器会自动计算SP的初始设定值,无需编程者关心。

8.程序状态寄存器PSW的作用是什么?常用状态标识有哪几位?作用是什么? 答: PSW 是 8 位寄存器,用做程序运行状态的标识。 表4.7 PSW寄存器各位名称及地址

地址 D7H D6H D5H D4H D3H D2H D1H D0H 名称 C AC F0 RS1 RS0 OV F1 P

当CPU进行各种逻辑操作或算术运算时,为反映操作或运算结果的状态,把相应的标识 位置位或清 0。这些标识的状态,可由专门的指令来测试,也可通过指令读出。它为计算机 确定程序的下一步运行方向提供依据。PSW寄存器中各位的名称及地址如表4.7所示,下面

说明各标识位的作用。

●P:奇偶标识。该位始终跟踪累加器A的内容的奇偶性。如果有奇数个1,则置P为1,否则清0。在80C5l的指令系统中,凡是改变累加器A中内容的指令均影响奇偶标识位P。 ● F1:用户标识。由用户置位或复位。

●OV:溢出标识。有符号数运算时,如果发生溢出,OV置1,否则清0。对于1B的有 符号数,如果用最高位表示正、负号,则只有 7 位有效位,能表示-128~+127 之间 的数。如果运算结果超出了这个数值范围,就会发生溢出,此时,OV = l,否则OV

= 0。在乘法运算中,OV = l表示乘积超过 255;在除法运算中,OV = l表示除数为 0。 ● RS0、RSl:工作寄存器组选择位。用于选择指令当前工作的寄存器组。由用户用软 件改变RS0 和RSl的组合,以切换当前选用的工作寄存器组,单片机在复位后, RS0 = RSl = 0,CPU自然选中第0组为当前工作寄存器组。根据需要,用户可利用传送指 令或位操作指令来改变其状态,这样的设置为程序中快速保护现场提供了方便。 ●F0:用户标识位,同F1。

● AC:半进位标识。当进行加法(或减法)运算时,如果低半字节(位 3)向高半字

节(位 4)有进位(或借位) ,AC置 1,否则清 0。AC也可用于BCD码调整时的判别 位。

● CY:进位标识。在进行加法(或减法)运算时,如果操作结果最高位(位 7)有进 位,CY置1,否则清0。在进行位操作时,CY又作为位操作累加器C。

9.在 80C51 扩展系统中,片外程序存储器和片外数据存储器共处同一地址空间为什么 不会发生总线冲突?

答: 在80C51扩展系统中,片外程序存储器和片外数据存储器虽然共处同一地址空间,但是在物理上是两个独立的存储空间,这两个空间都使用相同的16位地址线和8位数据线,分别为两个64KB的寻址空间,它们的选通控制信号不同。程序存储器使用PSEN 作为取指令控制信号,数据存储器使用WR 、RD作为存取数据控制信号。所以不会发生总线冲突。 从指令周期角度来看,取指令周期访问片外程序存储器,PSEN 有效,执行指令周期则存 取数据,WR 、RD信号有效,访问的是片外数据存储器。 11.阐明“准双向口”这一名词之所以要加“准”字的理由。

答: ① 80C51的32条I/O线隶属于4个8位双向端口,每个端口均由锁存器(即特殊功能寄存器P0~P3) 、输出驱动器和输入缓冲器组成;

② P1、P2 和 P3 口均有内部上拉电阻,当它们用做通用 I/O 时,在读引脚状态时,各口 对应的锁存器必须置1,所以为准双向口;

③ P0口内部无上拉电阻,作为I/O口时,必须外部上拉电阻到电源。在读引脚状态时, 各口对应的锁存器必须置1,所以为准双向口;

80C51的32条I/O在读引脚状态时,各口对应的锁存器必须置1,即先写1,保证锁存器 的输出为1,然后再读引脚,方可读到正确的引脚状态。所以为准双向口。

12.何谓时钟周期、机器周期、指令周期?80C51 的时钟周期、机器周期、指令周期是 如何分配的?当振荡频率为8MHz时,一个单片机机器周期为多少微秒?

答: 为了便于对CPU时序进行分析,人们按指令的执行过程规定了几种周期,即时钟周期、状态周期、机器周期和指令周期,也称为时序定时单位,下面分别予以说明。 时钟周期也称为振荡周期,定义为时钟脉冲频率(fosc)的倒数,是计算机中最基本、 最小的时间单位。

时钟周期经2分频后成为内部的时钟信号,用做单片机内部各功能部件按序协调工作的 控制信号,称为状态周期,用S表示。这样一个状态周期就有两个时钟周期,前半状态周期相应的时钟周期定义为P1,后半周期对应的节拍定义为P2。

完成一个基本操作所需要的时间称为机器周期,也称CPU周期。80C51有固定的机器周 期,规定一个机器周期有6个状态,分别表示为S1~S6,而一个状态包含两个时钟周期,那么一个机器周期就有12个时钟周期。 所以当振荡频率为8MHz时,

机器周期为 12×1/8MHZ=12×0.125μs=1. 5μs

13.复位的作用是什么?有几种复位方法?复位后单片机的状态如何?

答: 复位是单片机的初始化操作。单片机系统在上电启动运行时,都需要先复位,其作用是使CPU和系统中其他部件都处于一个确定的初始状态,并从这个状态开始工作。 单片机的外部复位电路有上电自动复位和按键手动复位两种。

当80C51通电,时钟电路开始工作,在80C51单片机的RST(DIP40封装第9脚)引脚 加上大于24个时钟周期以上的正脉冲,80C51单片机系统即初始复位。初始化后,程序计数器PC指向0000H,P0~P3输出口全部为高电平,堆栈指针写入07H,其他专用寄存器被清0。RST由高电平下降为低电平后,系统从0000H地址开始执行程序。 14.80C51有几种低功耗方式?如何实现?

答: 80C51 单片机除具有一般的程序执行方式外,还具有两种低功耗运行方式:待机(或称空闲)方式和掉电(或称停机)方式,备用电源直接由 VCC 端输入。第一种方式可使功耗减小,电流一般为1.7~5mA;第二种方式可使功耗减到最小,电流一般为5~50μA。可见,CHMOS型单片机特别适合于低功耗应用场合。

15. 何谓单片机最小系统?请分别画出由80C32单片机和89C52单片机组成的最小系统。 答: 单片机最小系统就是能使单片机工作的最少的器件构成的系统,是大多数控制系统必不可少的关键部分。80C32单片机和89C52单片机组成的最小系统如图4.2和图4.3所示。

习题4

1.80C51的指令系统具有哪些特点?

答 80C51指令系统由49条单字节指令、45条双字节指令和17条三字节指令组成,这样可以提高程序存储器的使用效率。对于大多数算术、逻辑运算和转移操作,可选用短地址或长地址指令实现,以提高运算速度、编程效率和节省存储器单元。在111条指令中,有64条指令的执行时间为12个振荡器周期 (1个机器周期) , 45条为24个振荡器周期 (2个机器周期) ,

只有乘、除法指令需48个振荡周期(4个机器周期) 。当主频为12MHz时,典型指令的执行时间为1μs,运算速度是比较快的。

2.80C51单片机的指令系统按其功能可归纳为几大类?请写出各类名称。 答: 80C51单片机指令系统操作码助记符按功能可分为五大类。 (1)数据传送类指令(7种助记符) (2)算术运算类指令(8种助记符) (3)逻辑运算类指令(10种助记符) (4)控制转移类指令(18种助记符) (5)位操作指令(1种助记符)

3.何为寻址方式?80C51单片机有哪些寻址方式? 答: 80C51 单片机共有 7 种寻址方式: ● 寄存器寻址 ● 寄存器间接寻址 ● 直接寻址 ● 立即寻址

● 基址寄存器+变址寄存器的间接寻址 ● 相对寻址 ● 位寻址

4.什么是源操作数?什么是目的操作数?通常在指令中如何加以区分?

答: 在双操作数的指令中,指令执行后的结果放在其中的一个操作数中,这个操作数是目的操作数,另外一个是源操作数。80C51 指令系统中,不靠近指令操作码的是源操作数,源操作数可以是立即数。80C51 指令系统中,紧跟在指令操作码之后是目的操作数,算术运算和大多数逻辑运算其目的操作数必须是累加器A,目的操作数不允许使用立即数寻址方式。

5.查表指令是在什么空间上的寻址操作?

答: 由于对程序存储器只能读而不能写,因此其数据传送是单向的,即从程序存储器读取数据,且只能向累加器A传送。这类指令共有两条,其功能是对存放于程序存储器中的数据表格进行查找传送,所以又称查表指令。 MOVC A,@A+DPTR

MOVC A,@A+PC

这两条指令都为变址寻址方式。前一条指令以DPTR作为基址寄存器进行查表,使用前 可先给 DPTR 赋予任何地址,因此查表范围可达整个程序存储器的 64KB 空间。后一条指令以PC作为基址寄存器,虽然也提供16位基址,但其值是固定的。由于A的内容为8位无符号数,所以这种查表指令只能查找所在地址以后256B范围内的常数或代码。

6.对80C51片内RAM的128~255字节区的地址空间寻址时,应注意些什么?对特殊 功能寄存器,应采用何种寻址方式进行访问?

答: 此空间有2类不同的物理存储空间,一个是特殊功能寄存器区,一个是RAM区。 直接寻址访问特殊功能寄存器,间接寻址访问RAM区。 7.写出完成下列要求的C语言程序。

(1)将地址为4000H的片外数据存储单元内容,送入地址为30H的片内数据存储单元 中。

答: 可使用绝对地址访问函数实现 DBYTE[0x30] = XBYTE[0x4000];

(2)将地址为4000H的片外数据存储单元内容,送入地址为3000H的片外数据存储单 元中。

答: 可使用绝对地址访问函数实现 XBYTE [0x3000] = XBYTE[0x4000]; (3)将地址为0800H的程序存储单元内容,送入地址为30H的片内数据存储单元中。 答: 可使用绝对地址访问函数实现 DBYTE [0x30] = CBYTE[0x0800]; (4)将片内数据存储器中地址为30H与40H的单元内容交换。 答: unsigned char temp; temp= DBYTE [0x40];

DBYTE [0x40]= DBYTE [0x30]; DBYTE [0x30]= temp;

此题答案不唯一,也可用指针运算或其他方案实现;

(5)将片内数据存储器中地址为30H单元的低4位与高4位交换。 答: 使用C51提供的本征函数_cror_实现; #inclucle

_cror_(DBYTE [0x30],4);

8.将30H、31H单元中的十进制数与38H、39H单元中的十进制数做十进制加法,其和 送入40H、41H单元中,即(31H,30H)+(39H,38H)→(41H,40H)。 答: #include //片内寄存器定义 #include

/*********** main C **************/ void main (void) { unsigned int sum;

sum = DBYTE[0x30]+DBYTE[0x38];

if((sum&0x000f)>0x9) sum += 0x06; //个位十进制调整 if(sum>0x99) sum += 0x60;//十位十进制调整 DBYTE[0x40]= sum;//和低位字节

DBYTE[0x41] = (sum>>8) + DBYTE[0x31]+DBYTE[0x39];//和高位字节 if(DBYTE[0x41]>0x09) DBYTE[0x41] += 0x06;//百位十进制调整 while(1); /* 程序在此死循环 */ }

9.编写程序段完成下列乘法操作: (R4,R3)×(R5),(32H,31H,30H)。此式含义


单片机课后习题答案[1]1.doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:最新重大危险源公示牌(完整)

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: