单片机第三章答案解析.docx
《单片机第三章答案解析.docx》由会员分享,可在线阅读,更多相关《单片机第三章答案解析.docx(19页珍藏版)》请在冰豆网上搜索。
单片机第三章答案解析
思考题:
【3-1】汇编语言与C语言哪种语言的可读性和可移植性强?
在对速度和时序敏感的场合应该使用什么语言?
对于复杂的单片机系统一般采用C与汇编混合编程的形式这句话对吗?
【3-2】二进制机器语言与C和汇编语言两者之间是什么关系?
用C或汇编编制的程序在ROM中是以编译后的二进制代码的形式存放这句话对吗?
【3-3】80C51系列单片机指令的格式包含哪几个部分?
各部分之间的间隔符是什么?
四个部分中哪个部分是必须存在的,哪几个部分是可有可无的?
标号的格式和代表的意义是?
【3-4】80C51系列单片机有哪几种寻址方式?
【3-5】80C51单片机中立即数是存放在ROM中还是RAM中?
【3-6】判断下列说法是否正确。
(1)立即数寻址方式是被操作的数据本身就在指令中,而不是它的地址在指令中。
()
(2)指令周期是执行一条指令的时间。
()
(3)指令中直接给出的操作数称为直接寻址。
()
(4)内部寄存器Rn(n=0~7)可作为间接寻址寄存器。
()
【3-7】80C51单片机可以进行直接寻址的区域是?
【3-8】80C51单片机可以进行寄存器寻址的范围是?
【3-9】80C51单片机可以进行寄存器间接寻址的寄存器是?
寻址的范围是?
【3-10】在寄存器间接寻址方式中,其“间接”体现在指令中寄存器的内容不是操作数,而是操作数的()。
【3-11】80C51单片机变址寻址方式中可以作基址的寄存器是?
可以作变址的寄存器是?
@A+PC,@A+DPTR所找到的操作数是在ROM中对吗?
【3-12】80C51单片机相对寻址改变的是PC的当前值,即改变的CPU执行指令的顺序这句话对否?
【3-13】若访问特殊功能寄存器,只可以采用那种寻址方式?
【3-14】若访问外部RAM单元,只可以使用哪种寻址方式?
【3-15】若访问内部RAM单元,可使用哪些寻址方式?
【3-16】若访问内外程序存储器,可使用哪些寻址方式?
【3-17】80C51单片机可以进行位寻址的字节单元范围除11个可位寻址的特殊功能寄存器外还包括哪个区域?
分别找出位地址是00H、08H、22H、7FH、D0H、E0H对应的字节地址?
【3-18】已知(30H)=40H,(40H)=10H,(10H)=32H,(P1)=0EFH,试写出执行以下程序段后有关单元的内容。
MOVR0,#30H
MOVA,@R0
MOVR1,A
MOVB,@Ri
MOV@R1,P1
MOVP2,P1
MOV10H,#20H
MOV30H,10H
【3-19】为什么对基本型的51子系列单片机(片内RAM为128B),其寄存器间接寻址方式(例如MOVA,@R0)中,规定R0或R1的内容不能超过7FH?
【3-20】外部RAM数据传送指令有几条?
试比较下面每一组中两条指令的区别?
(1)MOVXA,@R1MOVXA,@DPTR
(2)MOVXA,@DPTRMOVX@DPTR,A
(3)MOV@R0,AMOVX@R0,A
(4)MOVCA,@A+DPTRMOVXA,@DPTR
【3-21】假定累加器A中的内容为30H,执行指令1000H:
MOVCA,@A+PC后,把程序存储器()单元的内容送入累加器A中。
【3-22】在AT89S51中,PC和DPTR都用于提供地址,但PC是为访问()提供地址,而DPTR是为访问()和()提供地址。
【3-23】试写出完成以下数据传送的指令序列。
(1)R1的内容传送R0;
(2)片外RAM60H单元的内容送入R0;
(3)片外RAM60H单元的内容送入片内RAM40H单元;
(4)片外RAM1000H单元的内容送入片外RAM40H单元。
【3-24】试编程,将外部RAM1000H单元中的数据与内部RAM60H单元中的数据相互交换。
【3-25】对程序存储器的读操作。
只能使用()。
A)MOV指令B)PUSH指令C)MOVX指令D)MOVC指令
【3-26】(DPTR)=507BH,(SP)=32H,(30H)=50H,(31H)=5FH,(32H)=3CH,则执行下列指令后,(DPH)=(),(DPL)=(),(SP)=()。
POPDPH
POPDPL
POPSP
【3-27】假定,(SP)=60H,(A)=30H,(B)=70H,执行下列指令后,SP的内容为(),61H单元的内容为(),62H单元的内容为()。
PUSHAcc
PUSHB
【3-28】已知程序执行前有(A)=02H,(SP)=52H,(51H)=FFH,(52H)=FFH。
下述程序执行后,(A)=(),(SP)=(),(51H)=(),(52H)=(),(PC)=()。
POPDPH
POPDPL
MOVDPTR,#4000H
RLA
MOVB,A
MOVCA,@A+DPTR
PUSHAcc
MOVA,B
INCA
MOVCA,@A+DPTR
PUSHAcc
RET
ORG4000H
DB10H,80H,30H,50H,30H,50H
【3-29】已知(A)=5BH,(R1)=40H,(40H)=C3H,(PSW)=81H,试写出各条指令的执行结果,并说明程序状态字的状态。
(1)XCHA,R1
(2)XCHA,40H
(3)XCHA,@R1
(4)XCHDA,@Rl
(5)SWAPA
(6)ADDA,R1
(7)ADDA,40H
(8)ADDA,#40H
(9)ADDCA,40H
(10)SUBBA,40H
(11)SUBBA,#40H
【3-30】试分析下面两组指令的执行结果有何不同?
(1)MOVA,#0FFH
(2)MOVA,#0FFH
INCAADDA,#O1H
【3-31】DAA指令有什么作用?
怎样使用?
【3-32】已知(A)=87H,(R0)=42H,(42H)=24H,请写出执行下列程序段后A的内容。
ANLA,#23H
ORL42H,A
XRLA,@R0
CPLA
【3-33】写出完成如下要求的指令.但是不能改变未涉及位的内容。
(1)把Acc.3,Acc.4,Acc.5和Acc.6清0。
(2)把累加器A的中间4位清0。
(3)把Acc.2和Acc.3置1。
【3-34】假定(A)=83H,(R0)=17H,(17H)=34H,执行以下指令后,(A)=()。
ANLA,#17H
ORL17H,A
XRLA,@R0
CPLA
【3-35】假设(A)=55H,(R3)=0AAH,在执行指令“ANLA,R3”后,(A)=(),(R3)=()。
【3-36】已知组合逻辑关系式为F=AB+C,请编写模拟其功能的程序。
设A、B、C、F均代表位地址。
【3-37】编程完成下述操作。
(1)将外部RAM1000H单元的所有位取反;
(2)将外部RAM60H单元的高2位清零,低两位变反,其余位保持不变。
【3-38】试用位操作指令实现逻辑操作:
P1.0=(10H∨P1.0),PSW.1=(18H∨CY)。
【3-39】仔细辨析下列指令的意义,找出错误的指令,并简要说明原因。
(1)CLRA
(2)CLREOH
(3)CLRACC
(4)CLRACC.0
(5)CPLA
(6)CPLEOH
(7)CPLACC
(8)CPLACC.0
【3-40】指令LJMPaddrl6和AJMPaddrl1的区别是什么?
【3-41】试分析以下两段程序中各条指令的作用,程序执行完将转向何处?
(1)MOVp1,#0CAH
MOVA,#56H
JBP1.22,L1
JNBACC.3,L2
……
L1:
:
L2:
:
(2)MOVA,#43H
JBACC.2,L1
JBCACC.6,L2
……
L1:
:
L2:
:
【3-42】判断以下指令的正误。
(1)MOV28H,@R2;
(2)DECDPTR;
(3)INCDPTR;
(4)CLRR0;
(5)CPLR5
(6)MOVR0,R1;
(7)PUSHDPTR;
(8)MOVF0,C;
(9)MOVF0,Acc.3;
(10)MOVXA,@R1;
(11)MOVC,30H;
(12)RLCR0
【3-43】借助指令表(附录B),对如下指令代码(十六进制)进行手工反汇编。
FFC0E0E5F0
【3-44】以下指令中,属于单纯读引脚的指令是()。
A)MOVP1,A
B)ORLP1,#0FH
C)MOVC,Pl.5
D)ANLP1,#0FH
【3-45】用AT89S51单片机的P1口做输出,经驱动电路接8个发光二极管,见图3-11所示。
当输出位为“0”时,发光二极管点亮;输出为“1”时,发光二极管为暗。
试编制程序①将8个发光二极管全部点亮;②将8个发光二极管全部熄灭;③将8个发光二极管隔一个点亮一个;④每次亮一个,循环左移,一个一个地亮,循环不止。
图3-11单片机P1口驱动发光二极管
【3-46】如图3-12所示,这是由AT89C51构建的最小系统,外部连接了4个按键S1~S4及4个发光二极管LEDl-LED4,P1口的高4位用于接收按键的输入状态,而低4位用于驱动发光二极管。
请结合图示,编写程序,完成以下要求。
(1)若Sl闭合,则发光二极管LEDl点亮;若S2闭合,则发光二极管.LED2点亮……。
以此类推,即发光二极管实时反映按键状态。
(2)用4个发光二极管实现对按键键值的BCD编码显示。
即若Sl闭合,键值为1,编码为0001,LEDl点亮;若S2闭合,键值为2,编码为0010,LED2点亮;若S3闭合,键值为3,编码为0011,LEDI、LED2同时点亮;若S4闭合,键值为4,编码为0100,LED3点亮。
图3-12
第三章思考题答案:
【3-1】解答:
(1)C语言那种语言的可读性和可移植性强,例如对于用C语言编制的51单片机程序,只需要稍作修改就可以移植到PIC类型的单片机上。
(2)汇编语言适用于对速度和时序敏感的场合。
(3)正确。
【3-2】解答:
(1)C语言与汇编语言经过编译后将是二进制的机器语言。
(2)正确。
【3-3】解答:
(1)一条完整的汇编语言指令包括标号、操作码、操作数和注释四部分。
(2)其中标号与操作码用冒号分隔,操作码和操作数之间用空格,多个操作数之间用逗号分隔,注释用冒号开头。
(3)四个部分中操作码是必须存在的,其他三部分在有的指令中可以不出现。
(4)标号是一种符号地址。
标号以字母开头,由1-8个字母或数字组成。
【3-4】解答:
80C51系列单片机提供了七种寻址方式:
立即寻址、直接寻址、寄存器寻址、寄存器间接寻址、变址寻址(基址寄存器+变址寄存器间接寻址)、相对寻址、位寻址。
【3-5】解答:
立即寻址寻址方式中的立即数是存放在ROM中。
【3-6】解答:
(1)正确
(2)正确(3)错误(4)错误
【3-7】解答:
直接寻址方式可访问以下存储空间:
①内部RAM低128个字节单元,指令中直接地址以单元地址的形式给出。
②特殊功能寄存器。
【3-8】解答:
寄存器寻址中规定的寄存器有:
①工作寄存器R0~R7。
②累加器A。
③双字节AB。
④数据指针DPTR。
【3-9】解答:
(1)能用于间接寻址的寄存器有R0,R1,DPTR,SP。
其中R0、R1必须是工作寄存器组中的寄存器。
(2)采用R0、R1作为间址寄存器,可寻址内部RAM的低128个单元和外部RAM低256个单元单元;采用16位的DPTR作为间址寄存器,可寻址外部RAM的整个64KB地址空间。
【3-10】解答:
地址。
【3-11】解答:
(1)80C51单片机变址寻址方式中是以DPTR或PC作基址寄存器,以累加器A作变址寄存器。
(2)是的。
@A+PC,@A+DPTR寻址所找到的操作数是在ROM中。
【3-12】解答:
正确。
80C51单片机凡是指令中带有rel相对偏移量的指令,其PC的改变都是相对的。
【3-13】解答:
若访问特殊功能寄存器,只可以采用直接寻址。
【3-14】解答:
若访问外部RAM单元,只可以使用寄存器间接寻址方式。
【3-15】解答:
若访问内部RAM单元,可使用直接寻址、寄存器寻址、寄存器间接寻址和位寻址。
【3-16】解答:
若访问内外程序存储器,可使用变址寻址方式。
【3-17】解答:
(1)还包含内部RAM的20H-2FH,共16个字节,16*8=128个位,每一位都有一个位地址,对应位地址00H-7FH。
(2)位地址是00H、08H、22H、7FH、D0H、E0H对应的字节地址分别是20H、21H、24H、2FH、D0H、E0H。
【3-18】解答:
R0←30H,(R0)=30H
A←((R0)),(A)=40H
R1←(A),(R1)=40H
B←((R1)),(B)=10H
(R1)←(P1),((R1))=(40H)=EFH
P2←(P1),(P2)=EFH
10H←20H,(10H)=20H
30H←(10H),(30H)=20H
结果:
(R0)=30H,(A)=40H,(R1)=40H,(B)=10H,(40H)=EFH,(P2)=EFH,(10H)=20H,(30H)=20H
【3-19】解答:
因为寄存器间接寻址方式中R0或R1的内容是操作数的RAM地址,内部RAM的寻址范围是00H~7FH。
【3-20】解答:
外部数据传送指令有4条:
MOVXA,@DPTR;MOVX@DPTR,A;MOVXA,@Ri;MOVX@R,A。
(1)都是访问片外RAM,但二者寻址范围不同。
前1条指令是对片外RAM低256个单元的“读”操作;后1条指令是对片外RAM64KB空间的“读”操作。
(2)访问空间相同,但数据传送方向不同。
前1条指令是对片外RAM64KB空间的“读”操作;后1条指令是对片外RAM64KB空间的“写”操作。
(3)访问空间不同。
前1条指令是对片内RAM低128个单元的“写”操作;后1条指令是对片外RAM低256个单元的“写”操作。
(4)二者访问的空间不同,寻址方式不同。
前1条指令是变址寻址方式,对ROM操作;后1条指令是寄存器间接寻址方式,对片外RAM操作。
【3-21】解答:
1031H。
【3-22】解答:
ROM;ROM和外部RAM。
【3-23】解答:
(1)由于在工作寄存器与工作寄存器之间不能直接传送数据,所以需要借助累加器A。
MOVA,R1
MOVR0,A
(2)片外RAM向片内RAM传送数据,不能直接进行,需要借助累加器A。
由于片外RAM是60H单元,地址小于FFH,所以间址寄存器使用Ri即可。
MOVR1,#60H
MOVXA,@R1
MOVR0,A
(3)MOVR1,#60H
MOVXA,@R1
MOV40H,A
(4)片外数据不能直接送入片外单元,需要先将片外数据读入累加器,然后再送到片外。
MOVDPTR,#1000H
MOVXA,@DPTR
MOVR1,#40H
MOVX@R1,A
【3-24】解答:
片外RAM与片内RAM之间的数据传送不能直接进行,需要借助累加器A。
数据交换需要使用数据交换指令XCH。
MOVDPTR,#1000H
MOVXA,@DPTR
XCHA,60H
MOVX@DPTR,A
【3-25】解答:
D。
【3-26】解答:
3CH;5FH;50H。
【3-27】解答:
30H;70H。
【3-28】解答:
50H;52H;30H;50H;5030H。
【3-29】解答:
(1)结果:
(A)←→(R1),(A)=40H,(R1)=5BH,(PSW)=81H
(2)结果:
(A)←→(40H),(A)=C3H,(40H)=5BH,(PSW)=80H
(3)结果:
(A)←→((R1)),(A)=C3H,((R1))=(40H)=5BH,(PSW)=80H
(4)结果:
(A)0~3←→((R1))0~3,(A)=53H,((R1))=(40H)=CBH,(PSW)=80H
(5)结果:
(A)0~3←→(A)4~7,(A)=B5H,(PSW)=81H
(6)结果:
A←(A)+(R1),(A)=9BH,(PSW)=05H
(7)结果:
A←(A)+(40H),(A)=1EH,(PSW)=80H
(8)结果:
A←(A)+40H,(A)=9BH,(PSW)=05H
(9)结果:
A←(A)+(40H)+CY,(A)=1FH,(PSW)=81H
(10)结果:
A←(A)-(40H)-CY,(A)=97H,(PSW)=85H
(11)结果:
A←(A)-40H-CY,(A)=1AH,(PSW)=01H
【3-30】解答:
(1)该组指令执行后(A)=00H,不影响CY位。
(2)该组指令执行后(A)=00H,影响CY位。
说明:
单独执行INC指令,只影响奇偶标志位P,不影响半进位标志位AC和进位位CY位。
执行ADD指令后,将影响CY、AC和P位。
【3-31】解答:
DAA指令的作用是对A中刚进行的两个BCD码的加法结果进行修正,即继续使BCD码加法运算的结果保持为BCD码。
使用时,DAA指令只能使用在加法指令后,即ADD指令和ADDC指令。
【3-32】解答:
A←(A)∧23H,(A)=03H
42H←(42H)∨(A),(42H)=37H
A←(A)
((R0)),(A)=34H
A←(
),(A)=CBH
结果:
(A)=CBH
【3-33】解答:
(1)ANLA,#87H
(2)ANLA,#0C3H
(3)ORLA,#0CH
【3-34】解答:
0CBH。
【3-35】解答:
00H;0AAH。
【3-36】解答:
ANLA,B
ORLA,C
MOVF,C
【3-37】解答:
(1)MOVDPTR,#1000H
MOVXA,@DPTR
CPLA
MOVX@DPTR,A
(2)MOVR0,#60H
MOVXA,@R0
ANLA,#3FH
XRLA,#03H
MOVX@R0,A
【3-38】解答:
(1)MOVC,10H
ANLC,P1.0
(2)ORLC,18H
MOVPSW.1,C
【3-39】解答:
(1)正确。
(2)错误。
原因:
清零指令只能用于累加器ACC和位操作,而本题中E0H只能是字节地址(位地址的范围是00H~7FH),所以该条指令错误。
(3)错误。
原因:
ACC是直接字节地址,不能用于清零指令。
(4)正确。
ACC.0是一个位,可以应用到清零指令中。
(5)正确。
(6)错误。
原因:
取反指令只能用于累加器ACC和位操作,而本题中E0H只能是字节地址(位地址的范围是00H~7FH),所以该条指令错误。
(7)错误。
原因:
ACC是直接字节地址,不能用于取反指令。
(8)正确。
ACC.0是一个位,可以应用到取反指令中。
【3-40】解答:
指令LJMPaddr16是长转移指令,指令中提供了16位目的地址,寻址范围是64KB。
指令AJMPaddr11是绝对转移指令,指令中11位目的地址,其中a7~a0在第二字节,a10~a8则占据第一字节的高3位,寻址范围是与PC当前值(本指令所在地址+本条指令所占用的字节数2)在同一个2K的区域内。
【3-41】解答:
(1)MOVP1,#0CAH;P1←CAH,P1=CAH=11001010B
MOVA,#56H;A←56H,A=56H=01010110B
JBP1.2,L1;若P1.2=1,则转移至L1
JNBACC.3,L2;若ACC.3=0,则转移至L2
…
L1:
…
L2:
…
执行完本段程序后将转移至L2,因为P1.2=0,ACC.3=0,所以转至L2。
(2)MOVA,#43H;A←43H,A=43H=01000011B
JBACC.2,L1;若ACC.2=1,则转移至L1
JBCACC.6,L2;若ACC.6=1,则转移至L2,同时将ACC.6清零
…
L1:
…
L2:
…
执行完本段程序后将转移至L2,因为ACC.2=0,ACC.6=1,所以转至L2,并且将ACC.6清零。
【3-42】解答:
(1)错误。
可以做间接寄存器的只有R0和R1,不包括R2。
(2)错误。
(3)错误。
(4)错误。
CLR的操作数只能是C或bit。
(5)错误。
CPL的操作数只能是C或bit。
(6)错误。
两个寄存器间不能直接进行数据传送。
(7)错误。
PUSH指令时字节操作指令。
(8)正确。
(9)错误。
位传送指令只进行C和位地址间的数据互送。
(10)正确。
(11)正确。
位操作指令。
(12)错误。
RLC指令的操作数只能是A。
【3-43】解答:
(1)FF:
MOVR7,A
(2)C0:
PUSHdirect
(3)E0:
MOVXA,@DPTR
(4)E5:
MOVA,direct
(5)F0:
MOVX@DPTR,A
【3-44】解答:
C。
【3-45】解答:
(1)MOVA,#00H
MOVP1,A
(2)MOVA,#0FFH
MOVP1,A
(3)MOVA,#AAH(或是55H)
MOVP1,A
(4)MOVA,#0FEH
LOOP:
MOVP1,A
RLA
LCALLDELAY
SJMPLOOP
DELAY:
MOVR7,#01H
DELAY1:
MOVR6,#01H
DJNZR6,$
DJNZR7,DELAY1
RET
【3-46】解答:
(1)MOVA,P1
CPLA
ANLA,#0F0H
SWAPA
MOVP1,A
(2)LOOP:
JNBP1.4,L1
JNBP1.5,L2
JNBP1.6,L3
JNBP1.7,L4
LJMPLOOP
L1:
MOVP1,#01H
LJMPLOOP
L2:
MOVP1,#02H
LJMPLOOP
L3:
MOVP1,#03H
LJMPLOOP
L4:
MOVP1,#04H
LJMPLOOP