单片微型计算机原理与应用答案Word格式文档下载.docx
《单片微型计算机原理与应用答案Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《单片微型计算机原理与应用答案Word格式文档下载.docx(30页珍藏版)》请在冰豆网上搜索。
④当振荡频率为12MHz时,一个机器周期1微秒
2.7MCS-51单片机的控制信号、、有哪些功能?
是访问程序存储器控制信号。
当端接低电平时,则不管芯片内部是否有程序存储器,CPU只访问外部程序存储器。
对8031来说,因其内部无程序存储器,所以该引脚必须接地。
当端接高电平时,CPU访问内部程序存储器,但当PC(程序计数器)值超过某一值时,将自动转向片外程序存储器1000H地址继续执行程序。
是地址锁存允许信号。
当CPU访问外部存储器或I/O接口时,ALE输出脉冲的下降沿用于锁存16位地址的低8位。
在不访问外部存储器或I/O接口时,ALE端有周期性正脉冲输出,其频率为振荡频率的1/6。
但是,每当访问外部数据存储器或I/O接口时,在第二个机器周期中ALE只出现一次,即丢失一个ALE脉冲。
片外程序存储器读选通信号。
在CPU从外部程序存储器读取指令(或常数)期间,每个机器周期两次有效,但在访问外部数据存储器或I/O接口时,信号将不出现。
端可以驱动8个TTL负载。
2.9简述MCS-51内部数据存储器的存储空间分配。
内部数据存储器分为3个区域:
工作寄存器区(00H~1FH);
位寻址区(20H~2FH);
堆栈和数据缓冲器区(30H~7FH或30H~0FFH)。
2.10位地址和字节地址有何区别?
位地址20H具体在内存中什么位置?
MCS-51的位存储器由以内部RAM中20H~2FH单元和特殊功能寄存器中地址为8的倍数的特殊功能寄存器两部分组成。
其中每个单元的每一位都有一个位地址映像,它们既可以像普通内部RAM单元一样按字节存取,也可以对单元中的任何一位单独存取。
字节地址是内部RAM中和特殊功能寄存器中每个存储单元的地址。
位地址20H是内部RAM24H中的D0位。
2.118051的4个I/O口作用是什么?
8051的片外三总线是如何分配的?
MCS-51单片机有4个8位并行I/O端口,分别记作P0、P1、P2、P3口。
①在访问片外扩展存储器时,P0口分时传送低8位地址和数据,P2口传送高8位地址。
P1口通常作为通用I/O口供用户使用。
P3口具有第二功能,为系统提供一些控制信号。
在无片外扩展存储器的系统中,这4个口均可作为通用I/O端口使用。
在作为通用I/O端口使用时,这4个口都是准双向口。
②在访问片外扩展存储器时,片外三总线的构成:
P0口传送低8位地址经锁存器所存构成低8位地址总线,高8位地址总线由P2口构成。
P0口作为单片机系统的低8位地址/数据线分时复用,在低8位地址锁存后,P0口作为双向数据总线。
由P3口的第二功能输出数据存储器的读、写控制信号与片外程序存储器读选通信号,访问程序存储器控制信号,地址锁存允许信号构成控制总线。
习题3
3.1汇编语句是由4个部分(字段)构成的,简述各部分的含义。
汇编语句的4个部分为:
[标号:
][操作码][操作数];
[注释]
标号是用户设定的一个符号,表示存放指令或数据的存储单元地址。
标号由以字母开始的1―8个字母或数字串组成,以冒号结尾。
不能用指令助记符、伪指令或寄存器名来作标号。
标号是任选的,并不是每条指令或数据存储单元都要标号,只在需要时才设标号。
如转移指令所要访问的存储单元前面一般要设置标号。
一旦使用了某标号定义一个地址单元,在程序的其它地方就不能随意修改这个定义,也不能重复定义。
操作码是指令或伪指令的助记符,用来表示指令的性质或功能。
对于一条汇编语言指令,这个字段是必不可少的。
操作数给出参加运算(或其它操作)的数据或数据的地址。
操作数可以表示为工作寄存器名、特殊功能寄存器名、标号名、常数、表达式等。
这一字段可能有,也可能没有。
若有两个或三个操作数,它们之间应以逗号分开。
注释字段不是汇编语言的功能部分,只是增加程序的可读性。
言简意赅的注释是汇编语言程序编写中的重要组成部分。
3.2举例说明MCS-51单片机的7种寻址方式,各寻址方式的寻址空间。
立即寻址立即寻址方式的寻址空间为程序存储器。
例如:
MOVA,#3FH;
3FH→A
直接寻址直接寻址方式中操作数存储的空间有三种:
内部数据存储器的低128个字节单元(00H~7FH)
MOVA,30H;
(30H)→A
指令功能是把内部RAM30H单元中的内容送入累加器A。
⑵位地址空间
MOVC,00H;
直接位00H内容→进位位
⑶特殊功能寄存器
MOVIE,#85H;
立即数85H→中断允许寄存器IE。
寄存器寻址寄存器寻址方式的寻址空间为工作寄存器和特殊功能寄存器等。
MOVA,R6;
(R6)→A
寄存器间接寻址寄存器间接寻址空间为内部RAM128字节,外部RAM
MOVA,@R0;
((R0))→A
变址寻址变址寻址空间为程序存储器。
MOVCA,@A+DPTR;
((DPTR)+(A))→A
MOVCA,@A+PC;
((PC)+(A))→A
相对寻址相对寻址空间为程序存储器。
当前PC值是指相对转移指令所在地址(源地址)加转移指令字节数。
即:
当前PC值=源地址+转移指令字节数
偏移量rel是有符号的单字节数,以补码表示,相对值在-128~+127范围内,负数表示从当前地址向上转移,正数表示从当前地址向下转移。
所以转移的目的地址为:
目的地址=当前PC值+rel=源地址+转移指令字节数+rel
JNC2AH,JZF8H
位寻址位寻址空间为内部RAM20H~2FH的128位和SFR中的83位。
MOVC,30H,MOVP1.0,C
3.3指出下列指令的寻址方式和操作功能:
INC40H;
直接寻址(40H)+1→40H
INCA;
寄存器寻址(A)+1→A
INC@R2;
寄存器间接寻址((R2))+1→(R2)
MOVCA,@A+DPTR;
基址加变址寄存器寻址((A)+(DPTR))→A
MOVA,#6EH;
立即寻址6EH→A
SETBP1.0;
位寻址P1.0置1
3.4设内部RAM中3AH单元的内容为50H,写出当执行下列程序段后寄存器A、R0和内部RAM50H,51H单元的内容为何值?
MOVA,3AH;
(A)=50H
MOVR0,A;
(R0)=50H
MOVA,#00H;
(A)=00H
MOV@R0,A;
(50H)=00H
MOVA,#25H;
(A)=25H
MOV51H,A;
(51H)=25H
(A)=25H,(3AH)=50H,(R0)=50H,(50H)=00H,(51H)=25H
3.5设堆栈指针SP中的内容为60H,内部RAM30H和31H单元的内容分别为27H和1AH,执行下列程序段后,61H,62H,30H,31H,DPTR及SP中的内容将有何变化?
PUSH30H;
(SP)+1→SP,(30H)→61H
PUSH31H;
(SP)+1→SP,(31H)→62H
POPDPL;
(62)→DPL,(SP)-1→SP
POPDPH;
(61)→DPH,(SP)-1→SP
MOV30H,#00H;
00H→30H
MOV31H,#0FFH;
FFH→31H
(61H)=27H,(62H)=1AH,(30H)=00H,(31H)=FFH,(DPTR)=271AH,(SP)=60H
3.6设(A)=30H,(R1)=23H,(30H)=05H。
执行下列两条指令后,累加器A和R1以及内部RAM30H单元的内容各为何值?
XCHA,R1
XCHDA,@R1
(A)=25H,(R1)=30H,(30H)=03H
3.7设(A)=01010101B,(R5)=10101010B,分别写出执行下列指令后的结果
ANLA,R5;
(A)=00000000B,(R5)=10101010B
ORLA,R5;
(A)=10101010B,(R5)=10101010B
XRLA,R5;
(A)=00000000B
3.8设指令SJMPrel=7FH,并假设该指令存放在2113H和2114H单元中。
当该条指令执行后,程序将跳转到何地址?
程序将跳转到2194H地址
3.9简述转移指令AJMPaddr11,SJMPrel,LJMPaddr16及JMP@A+DPTR的应用场合。
AJMPaddr11这是在当前PC的2K字节范围内的无条件转移指令,把程序的执行转移到指定的地址。
SJMPrel这是相对跳转指令,其中rel为相对偏移量。
转向的目标地址是在当前PC的前128字节到后127字节之间。
LJMPaddR16执行这条指令时把指令的第二和第三字节分别装入PC的高位和低位字节中,无条件地转向指定地址。
转移的目标地址可以在64KB程序存储器地址空间的任何地方,不影响任何标志。
JMP@A+DPTR把累加器A中8位无符号数与数据指针DPTR中的16位数相加,将结果作为转移的目标地址送入PC,不改变累加器A和数据指针DPTR内容,也不影响标志。
本指令以DPTR内容作为基址,A的内容作为变址。
只要把DPTR的值固定,而给A赋予不同的值,即可实现程序的多分支转移。
3.10查指令表,写出下列两条指令的机器码,并比较一下机器码中操作数排列次序的特点。
MOV78H,80H;
858078
MOV78H,#80H;
757880
直接寻址单元传送到直接寻址单元的机器码是第二个操作数在前,而立即数传送到直接地址单元是第一个操作数在前,次序正好相反。
3.11试编写程序,查找在内部RAM30H~50H单元中1AH这一数据。
若找到1AH则将51H单元置为01H;
没找到则将51H单元置为00H。
参考程序如下
MOVR1,#2FH
LOOP1:
INCR1
CJNE@R1,#1AH,LOOP2
SJMPLOOP3
LOOP2:
CJNER1,#51,LOOP1
MOV51H,#00H
SJMPEND
LOOP3:
MOV51H,#01H
END:
RET
3.12若SP=60H,子程序标号MULT所在的地址为3A40H。
执行LCALLMULT指令后,堆栈指针SP和堆栈内容发生了什么变化?
(SP)=62H,(61H)=40H,(62H)=3AH
3.13假设外部存储器215AH单元的内容为3DH,执行下列指令后,累加器A中的内容为何值?
MOVP2,#21H
MOVR0,#5AH
MOVXA,@R0
(A)=3DH
习题4
4.1编程将数据存储器中以2A00H为首地址的100个连续单元清零。
CLRA
MOVR0,#64H
MOVDPTR,#2A00H
LOOP:
MOVX@DPTR,A
INCDPTR
DJNZR0,LOOP
END
4.2编程将片内50H~70H单元中的内容传送到以5C00H为起始地址的存储区中。
MOVDPTR,#5C00H
MOVR0,#50H
MOVA,@R0
MOVX@DPTR,A
INCR0
CJNER0,#70H,LOOP
4.3片外RAM区从1000H单元开始存有100个单字节无符号数,找出最大值并存入1100H单元中,试编写程序。
MOVDPTR,#1000H;
置片外RAM区首地址
MOVR0,#00H;
清R0
MOVR1,64H;
置计数初值100
MOVXA,@DPTR;
取片外RAM区的某个数送A
CJNZA,R0,NT1;
与R0中的数比较
NT1:
JCNT2;
(A)<
(R0)跳转到NT2
MOVRO,A;
若(A)(R0),则大数送RO
NT2:
INCDPTR;
修改数据块指针
DJNZR1,LOOP;
未完,循环
RET
4.4设有100个单字节有符号数,连续存放在以2100H为首地址的存储区中,试编程统计其中正数、负数、零的个数。
MOVR0,#00H;
置负数的计数初值
MOVR1,#00H;
置正数的计数初值
MOVR2,#00H;
置0的计数初值
MOVR4,#64H;
置循环计数初值
MOVDPTR,#2100H;
置数据区首地址
START:
MOVXA,@DPTR;
取某一数据送入A
JZEQUAL;
为0转EQUAL
JNBACC.7,POSI;
为正数转POSI
INCR0;
负数计数值加1
INCDPTR;
修改数据块指针
DJNZR4,START;
未完,返回
POSI:
INCR1;
正数计数值加1
DJNZR4,START
EQUAL:
INCR2;
0计数值加1
4.5从2030H单元开始,存有100个有符号数,要求把它传送到从20BOH开始的存储区中,但负数不传送,试编写程序。
MOVR1,#64H;
置计数初值
MOVR0,#B0H;
目标数据区首地址低8位,高8位为20H
MOVDPTR,#2030H;
源数据区首地址
取源数据区某数据送入A
JBACC.7,D1;
负数,转D1
MOVX@R0,A;
正数,送入目标数据区
修改源数据块指针
修改目标数据块指针
DJNZR1,START;
未完,继续
RET;
返回
D1:
修改源数据块指针
修改目标数据块指针
4.6若从30H单元开始有100个数,编一个程序检查这些数,正数保持不变,负数取补后送回。
MOVR0,#30H;
数据区首地址
计数初值
START:
MOVXA,@R0;
取某个数
JNBACC.7,POSI;
正数,转POSI
CPLA;
负数,取补
ADDA,#01H
MOVX@R0,A;
送回原地址
POSI:
INCR0;
4.7试编程把以2040H为首地址的连续10个单元的内容按升序排列,存到原来的存储区中。
SORT:
MOVDPTR,#2040H;
MOVR3,#09H;
CLRF0;
MOVXA,@DPTR;
MOVR2,A;
前一个数送R2
MOVR4,A;
后一个数送R4
MOVA,R2;
前一个数送A
CLRC
SUBBA,R4;
前一个数减后一个数
JCNEXT;
相邻数互换
MOVX@DPTR,A
MOVR0,DPL;
数据指针低8位减1
DECR0
MOVDPL,R0
MOVA,R4;
INCDPTR;
SETBF0
NEXT:
DJNZR3,D1;
JBF0,SORT
4.8设在2000H~2004H单元中.存放有5个压缩BCD码,编程将它们转换成ASCII码,存放到以2005H为首地址的存储区中。
MOVDPTR,#2000H;
MOVR0,#05H;
MOVR1,#04H;
MOVXA,@DPTR;
ANLA,#0FH
CLRC;
ADDA,#30H;
MOVP2,#20H
MOVX@R0,A
DJNZR1,D1;
在以2000H为首地址的存储区中,存放着20个用ASCII码表示的O~9之间的数,试编程,将它们转换成BCD码,并以压缩BCD码的形式存放在3000H~3009H单元中。
MOVDPTR,2000H;
MOVR0,#20H;
MOVR1,#00H;
ASCBIN:
SUBBA,#30H;
MOVP2,30H;
MOVX@R1,A;
INCR1;
DJNZR0,ASCBIN;
4.10试编写多字节BCD码数加法、减法子程序。
4.11若晶振为6MHz,试编写延时100ms、1s的子程序。
ORG2000H周期数
MOVR0,#0AH;
毫秒数→R01
DL2:
MOVR1,#MT;
1ms延时值→R11
DL1:
NOP1
NOP1
DJNZR1,DL1;
1ms延时循环2
DJNZR0,DL2;
10ms延时循环2
4.12试设计一个子程序,其功能为将片内RAM20H~21H中的压缩BCD码转换为二进制数,并存于以30H开始的单元。
BCDB:
MOVA,20H
MOVR2,A;
取千位、百位BCD码
ACALLBCDB1;
调用子程序
MOVB,#0AH
MULAB;
乘以10
MOVR6,A;
乘积低8位送R6
XCHA,B;
交换乘积高、低位
MOVR5,A;
乘积高位送R5
MOVA,21H;
取十位、个位BCD码
送入R2
ADDA,R6;
加千位、百位乘积低8位
MOV31H,A;
低8位送入31H
MOVA,R5;
乘积高8位送A
ADDCA,#00H;
加进位位
MOV30H,A;
结果高8位送入30H
HERE:
SJMPHERE
子程序清单:
BCDB1:
MOVA,R2;
取压缩BCD码
ANLA,#0F0H;
屏蔽低4位
SWAPA
高位BCD码乘以10
MOVR3,A;
乘积送R3
MOVA,R2;
ANLA,#0FH;
屏蔽高4位
ADDA,R3;
高位BCD码乘以10后加低位BCD码
送R2
习题5
5.1什么是中断系统?
中断系统的功能是什么?
当CPU正在处理某件事情(例如,正在执行主程序)的时候,外部或内部发生的某一事件(如某个引脚上电平的变化,一个脉冲沿的发生或计数器的计数溢出等)请求CPU迅速去处理,于是,CPU暂时终止当前的工作,转去处理所发生的事件。
中断服务程序处理完该事件后,再回到原来被终止的地方,继续原来的工作,这样的过程称为中断。
实现这种功能的部件称为中断系统。
中断系统的功能:
(1)实现中断及中断返回,
(2)实现优先级排队,(3)实现优先级控制。
5.2什么是中断嵌套?
当CPU响应某一中断源的请求而进行中断处理时,若有优先级更高的中断源发出中断请求,则CPU中断正在执行的中断服务程序,保留程序的断点和现场,响应更高一级的中断,即是中断嵌套。
5.3什么是中断源?
MCS-51有哪些中断源?
各有什么特点?
向CPU发出中断请求的来源称为中断源。
MC5-51单片机的中断系统有5个中断请求源:
⑴—外部中断0请求,由引脚输入,中断请求标志为IE0。
⑵—外部中断l请求,由引脚输入,中断请求标志为IEl。
⑶定时器/计数器T0溢出中断请求,中断请求标志为TF0。
⑷定时器/计数器T1溢出中断请求,中断请求标志为TF1。
⑸串行口中断请求,中断请求标志为TI或RI。
外部中断0:
它的触发方