您的当前位置:首页正文

单片机课后习题答案

2020-07-04 来源:好走旅游网


一)填空题 1. 十进制数14对应的二进制数表示为(1110B),十六进制数表示为(0EH)。十进制数-100的补码为(9CH),+100的补码为(64H)。

2. 在一个非零的无符号二进制整数的末尾加两个0后,形成一个新的无符号二进制整数,则新数是原数的(4)倍。 3. 8位无符号二进制数能表示的最大十进制数是(255)。带符号二进制数11001101转换成十进制数是(-51)。

4. 可以将各种不同类型数据转换为计算机能处理的形式并输送到计算机中去的设备统称为(输入设备)。

5. 已知字符D的ASCII码是十六进制数44,则字符T的ASCII码是十进制数(84)。 6. 若某存储器容量为640KB,则表示该存储器共有(655360)个存储单元。

7. 在计算机中,二进制数的单位从小到大依次为(位)、(字节)和(字),对应的英文名称分别是(bit)、(Byte)和(Word)。

8. 设二进制数A=10101101,B=01110110,则逻辑运算A∨B=(11111111),A∧B=(00100100),A⊕B=(11011011)。

9. 机器数01101110的真值是(+110),机器数01011001的真值是(+89),机器数10011101的真值是(+157或-115),机器数10001101的真值是(+206或-50)。

(二)单项选择题

1. 用8位二进制补码数所能表示的十进制数范围是(D)

(A)-127 ~ +127 (B)-128 ~ +128

(C)-127 ~ +128 (D)-128 ~ +127

2. 下列等式中,正确的是(B)

(A)1 KB = 1024×1024 B (B)1 MB = 1024×1024 B

(C)1 KB = 1024 M B (D)1 MB = 1024 B

3. 程序与软件的区别是(C)

(A)程序小而软件大 (B)程序便宜而软件昂贵

(C)软件包括程序 (D)程序包括软件

4. 存储器中,每个存储单元都被赋予惟一的编号,这个编号称为(A)

(A)地址 (B)字节 (C)列号 (D)容量

5. 8位二进制数所能表示的最大无符号数是(B)

(A)255 (B)256 (C)128 (D)127

6. 下列4个无符号数中,最小的数是(B)

(A)11011001(二进制) (B)37(八进制)

(C)75(十进制) (D)24(十六进制)

7. 下列字符中,ASCII码最小的是(B)

(A)a (B)A (C)x (D)X

8. 下列字符中,ASCII码最大的是(C)

(A)a (B)A (C)x (D)X

9. 有一个数152,它与十六进制数6A相等,那么该数是(B)

(A)二进制数 (B)八进制数 (C)十进制数 (D)十六进制数

第2章 80C51单片机的硬件结构

(一)填空题

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

2. 80C51单片机的时钟电路包括两部分内容,即芯片内的(高增益反相放大器反相器)和芯片外跨接的(石英晶体振荡器晶振)与(两个微调电容)。若调高单片机的晶振频率,则单片机的机器周期会变(短)。

3. 通常单片机有两种复位操作,即(上电复位)和(手动复位)。复位后,PC值为(0000H),SP值为(07H),通用寄存器的当前寄存器组为(第0)组,该组寄存器的地址范围是从(00H)到(07H)。

4. 80C51单片机中,一个机器周期包含(6)个状态周期,一个 状态周期又可

划分为(2)个拍节,一个拍节为(1)个振荡脉冲周期。因此,一个机器周期应包含(12)个振荡脉冲周期。

5. 80C51中惟一一个可供用户使用的16位寄存器是(DPTR),它可拆分为两个8位寄存器使用,名称分别为(DPH)和(DPL)。

6. 单片机程序存储器的寻址范围由PC的位数决定。80C51的PC为16位,因此程序存储器地址空间是(64 KB)。

(二)单项选择题

1. 下列概念叙述正确的是(D)

(A)80C51中共有5个中断源,因此在芯片上相应地有5个中断请求输入引脚

(B)特殊的存取规则使得堆栈已不是数据存储区的一部分

(C)可以把PC看成是数据存储空间的地址指针

(D)CPU中反映程序运行状态和运算结果特征的寄存器是PSW

2. 取指操作后,PC的值是(C)

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

(C)下一条指令的地址 (D)控制寄存器中指令寄存器的地址

3. 80C51单片机中,设置堆栈指针SP为37H后就发生子程序调用,这时SP的值变为(C)

(A)37H (B)38H (C)39H (D)3AH

4. 设置堆栈指针SP = 30H后,进行一系列的堆栈操作。当进栈数据全部弹出后,SP应指向(A)

(A)30H单元 (B)07H单元 (C)31H单元 (D)2FH单元

5. 下列关于堆栈的描述中,错误的是(C)

(A)80C51的堆栈在内部RAM中开辟,所以SP只需8位就够了

(B)堆栈指针SP的内容是堆栈栈顶单元的地址

(C)在80C51中,堆栈操作过程与一般RAM单元的读/写操作没有区别

(D)在中断响应时,断点地址自动进栈

6. 在单片机芯片内设置通用寄存器的好处不应该包括(A)

(A)提高程序运行的可靠性 (B)提高程序运行速度

(C)为程序设计提供方便 (D)减小程序长度

7. 下列叙述中正确的是(D)

(A)SP 内装的是堆栈栈顶单元的内容

(B)在中断服务程序中没有PUSH 和POP 指令,说明此次中断操作与堆栈

无关

(C)在单片机中配合实现“程序存储自动执行”的寄存器是累加器

(D)两数相加后,若A 中数据为66H,则PSW 中最低位的状态为0

第3 章 80C51 单片机指令系统

(一)填空题

1. 假定累加器A 中的内容为30H,执行指令“1000H: MOVC A, @A+PC”

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

2. 假定(A)=85H,(R0)=20H,(20H)=0AFH,执行指令“ADD A, @R0”

后,累加器A 的内容为(34H),CY 的内容为(1),AC 的内容为(1),OV

的内容为(1)。

3. 执行如下指令序列后,所实现的逻辑运算式为(P3.0 P1.0P1.1P1.2)

MOV C, P1.0

ANL C, P1.1

ANL C, /P1.2

MOV P3.0, C

4. 假定addr11=00100000000B,标号qaz 的地址为1030H,执行指令“qaz: AJMP

addr11”后,程序转移到地址(1100H)去执行。

5. 累加器A 中存放着一个其值小于或等于127 的8 位无符号数,CY 清0 后执

行“RLC A”指令,则A 中的数变为原来的(2)倍。

6. 已知A=7AH,R0=30H,(30H)=A5H,PSW=80H,请按要求填写各条指令

的执行结果(每条指令均按已给定的原始数据进行操作)。

XCH A, R0 A=(30H),R0=(7AH)

XCH A, 30H A=(0A5H)

XCH A, @R0 A=(0A5H)

XCHD A, @R0 A=(75H)

SWAP A A=(0A7H)

ADD A, R0 A=(0AAH),CY=(0),OV=(1)

ADD A, 30H A=( 1FH ),CY=(1),OV=(0)

ADD A, #30H A=(0AAH),CY=(0),OV=(1)

ADDC A, 30H A=( 20H ),CY=(1),OV=(0)

SUBB A, 30H A=(0D4H),CY=(1),OV=(1)

SUBB A, #30H A=( 49H ),CY=(0),OV=(0)

(二)单项选择题 1. 下列指令或指令序列中,不能实现PSW内容送A的是(C)

(A)MOV A, PSW (B)MOV A, 0D0H

(C)MOV R0, 0D0H (D)PUSH PSW

MOV A,@R0 POP ACC

2. 在相对寻址方式中,“相对”两字是指相对于(C)

(A)地址偏移量rel (B)当前指令的首地址

(C)下一条指令的首地址 (D)DPTR值

3. 下列指令或指令序列中,能将外部数据存储器3355H单元内容传送给A的是(B)

(A)MOVX A, 3355H (B)MOV DPTR, #3355H

MOVX A, @ DPTR

(C)MOV P0, #33H (D)MOV P2, #33H

MOV R0, #55H MOV R2, #55H

MOVX A, @ R0 MOVX A, @ R2

4. 对程序存储器的读操作,只能使用(D)

(A)MOV 指令 (B)PUSH 指令

(C)MOV X指令 (D)MOVC指令

5. 执行返回指令后,返回的断点是(C)

(A)调用指令的首地址 (B)调用指令的末地址

(C)调用指令的下一条指令的首地址 (D)返回指令的末地址

6. 以下各项中不能用来对内部数据存储器进行访问的是(A)

(A)数据指针DPTR (B)按存储单元地址或名称

(C)堆栈指针SP (D)由R0 或R1 作间址寄存器

(三)其他类型题

1. 判断下列指令的合法性(合法打“√”,非法打“×”)

MOV A, @R2 (×) MOV R0, R1 (×) INC DPTR (√)

MOV PC, #2222H (×) DEC DPTR (×) RLC R0 (×)

MOV 0E0H, @R0 (√) CPL R5 (×) CLR R0 (×)

CPL F0H (×) PUSH DPTR (×) POP 30H (√)

MOVX A, @R1 (√) MOV A, 1FH (√) MOV C, 1FH (√)

MOV F0, ACC.3 (×) MOV F0, C (√) MOV P1, R3 (√)

MOV DPTR, #0FCH(×) CPL 30H (√) PUSH R0 (×)

MOV C, #0FFH (×) MOV A, #0D0H(√)

2. 利用位操作指令序列实现下列逻辑运算。

(1)D=(10HP1.0)(11HCY)

MOV C, P1.0

ORL C, /10H

MOV F0, C

ORL C, 11H

ANL C, F0

MOV D, C

(2)E=ACC.2P2.7ACC.1P2.0

MOV C, ACC.2

ANL C, P2.7

ORL C, ACC.1

ANL C, P2.0

MOV E, C

3. 编写程序将内部RAM 20H ~ 23H 单元的高4 位写1,低4 位写0。

分析:就是把内部RAM 20H ~ 23H这4个单元写入0F0H。用一个DJNZ的循环。

ORG 0000H

MOV R0, #20H ; R0指向20H单元

MOV R1, #04H ; 4个单元

LOOP: MOV @R0, #0F0H ; 写入

INC R0

DJNZ R1, LOOP ; 循环4次

END

4. 在m和m+1单元中存有两个BCD数,将他们合并到m单元中,编写程序完成。

ORG 0030H

MOV R0, #m

MOV A, @R0 ANL A, #0FH SWAP A MOV @R0, A INC R0 MOV A, @R0 ANL A, #0FH DEC R0 ORL A, @R0 ; 将m单元中的BCD数送入累加器A

; 把m单元的高4位清0

; 将m单元中的BCD数移入高4位

; m单元高4位为BCD数,低4位为0

; 指向m+1单元

; 将m+1单元中的BCD数送入累加器A

; 把m+1单元的高4位清0

; 指向m单元

; 将和m+1单元和m单元内容合并

MOV @R0, A ; 合并后结果送m单元

END

5. 将内部RAM中从data单元开始的10个无符号数相加,其和送sum单元。假定相加结果小于255。编写程序完成。

ORG 0030H

MOV R0, #10 ; 给 R0 置计数器初值

MOV R1, # data ; 数据块首址送R1

CLR A ; A清零

LOOP: ADD A, @R1 ; 加一个数

INC R1 ; 修改地址,指向下一个数

DJNZ R0, LOOP ; R0 减 1,不为零循环

MOV sum, A ; 存 10 个数相加和

END

6. 假定8位二进制带符号数存于R0中,要求编写一个求补(取反)程序,所得补码放

入R1中。

分析:对存于R0中的二进制带符号数,如果是正数,则将其变成绝对值相等的负数(用补码表示);如果是负数(用补码表示),则将其变成绝对值相等的正数。

ORG 0030H

MOV A, R0 ; 将带符号数送入A

CPL A

ADD A, #01H ; 末位加 1

MOV R1, A ; 补码存入R1

END

第4章 单片机汇编语言程序设计

(一)填空题 1. 假定A=40H,R1=23H,(40H)= 05H。执行以下两条指令后,A=(25H),R1=(40H),(40H)=(03H)。

XCH A, R1 ; A=23H,R1=40H

XCHD A, @R1 ; A=20H,(40H)=03H

2. 假定80C51的晶振频率为6 MHz,执行下列程序后,在P1.1引脚产生的方波宽度为(5.804ms)

START: SETB P1.1 ; P1.1置1(1周期)

DL: MOV 30H, #03H ; 30H置初值(1周期)

DL0: MOV 31H, #0F0H ; 31H置初值(1周期)

DL1: DJNZ 31H, DL1 ; 31H减1,不为0重复执行(2周期)

DJNZ 30H, DL0 ; 30H减1,不为0转DL0(2周期)

CPL P1.1 ; P1.1 取反(1 周期)

SJMP DL ; 转DL(2 周期)

方波宽度={[(2*15*16+2+1)*3]+[(2*15*16+2+1)*3+1+2+1]}*2=5804s

3. 下列程序中,X、Y 和Z 为输入的8 位无符号二进制数,F 为输出的逻辑运

算结果。试画出该程序所模拟的组合逻辑电路。

MOV A, X

ANL A, Y

MOV R1, A

MOV A, Y

XRL A, Z

CPL A

ORL A, R1

MOV F, A

F=XY&

&

&

1

1

X

YZ

Y

Z

F

4. 分析下列跳转程序,程序中A 与30H 单元中的数都是符号数,说明当(A=

(30H))时转向LOOP1,当(A>(30H))时转向LOOP2,当(A<(30H))

时转向LOOP3。

MOV R0, A ; R0←A

ANL A, #80H

JNZ NEG ; A<0,转NEG

MOV A, 30H

ANL A, #80H

JNZ LOOP2 ; A≥0,(30H) <0,转LOOP2

SJMP COMP ; A≥0,(30H)≥0,转COMP

NEG: MOV A, 30H

ANL A, #80H

JZ LOOP3 ; A<0,(30H) ≥0,转LOOP3

COMP: MOV A, R0

CJNE A, 30H, NEXT ; A≠(30H),转NEXT

SJMP LOOP1 ; A=(30H),转LOOP1

NEXT: JNC LOOP2 ; A>(30H),转LOOP2

JC LOOP3 ; A<(30H),转LOOP3

综上分析可知,当A=(30H)时转向LOOP1,A>(30H)时转向LOOP2,A<(30H)时转向LOOP3。

5. 假定80C51的晶振频率为6 MHz,下列程序的执行时间为(30.696ms)。已知程序中前2条指令机器周期数为1,后4条指令机器周期数为2。

MOV R3, #15 1周期

DL1: MOV R4, #255 1周期

DL2: MOV P1, R3 2周期

DJNZ R4, DL2 2周期

DJNZ R3, DL1 2周期

RET 2周期

执行时间:T={[(2+2)*255+2+1]*15+2+1}*2=30696s

(二)编程题

1. 把长度为10H的字符串从内部RAM的输入缓冲区inbuf向位于外部RAM的输出缓冲区outbuf传送,一直进行到遇见回车或整个字符串传送完毕,试编程实现。

11

ORG 0030H

MOV R0, #inbuf

MOV DPTR, #outbuf

MOV R4, #10H

LOOP: MOV A, @R0 ; 从内部RAM取数

CJNE A,#0DH, LL ; 是否为回车符CR

SJMP STOP ; 是回车符,则转STOP,停止传送

LL: MOVX @ DPTR, A ; 不是回车符,则传送到外部RAM

INC R0

INC DPTR

DJNZ R4, LOOP ; 沒传送完则循环

STOP: SJMP $

2. 内部RAM从list单元开始存放一正数表,表中之数作无序排列,并以﹣1作结束标志。编程实现找出表中最小数。

分析:从list+1单元开始判断其中的数是否为-1,将比较得到的小数放入累加器A

ORG 0030H

MOV R0, #list

MOV A, @R0 ;取第一个正数

LOOP: INC R0 ;指向下一个正数

MOV 30H, @R0

CJNE A, 30H, CHK ;前一个数与后一个数比较

CHK: JC LOOP1 ;前一个数小,则转LOOP1

MOV A, 30H ;前一个数大,取后一个数

LOOP1: XCH A, 30H

CJNE A, #0FFH, LOOP ;判断后一个数是否为-1

XCH A, 30H ;取最小数

SJMP $

3. 内部RAM的X,Y 单元中各存放一个带符号的数,试编程实现按如下条件进行的运算,并将结果存入Z单元中。

若X为正奇数,Z =X+Y;

若X为正偶数,Z =X∨Y;

若X为负奇数,Z =X∧Y;

若X为负偶数,Z =X⊕Y。

分析:正数:第7位为0,负数:第7位为1;奇数:第0位为1,偶数:第0位为0

方法1:利用ANL指令判断正负、奇偶

ORG 0030H

MOV A, X

ANL A, #80H JNZ NEG MOV A, X ANL A, #01H JZ EVEN1 MOV A, X

ADD A, Y SJMP RESULT

EVEN1: MOV A, X

; 判断X正负

; 若X为负,转NEG

; X为正

; 判断X奇偶

; 若X为偶数,转EVEN1

; 若X为正奇数,Z=X+Y

ORL A, Y ; 若X为正偶数,Z=X∨Y

SJMP RESULT

NEG: MOV A, X ; X为负

ANL A, #01H ; 判断X奇偶

JZ EVEN2 ; 若X为偶数,转EVEN2

MOV A, X

ANL A, Y ; 若X为负奇数,Z=X∧Y

SJMP RESULT

EVEN2: MOV A, X ; 若X为负偶数,Z=X⊕Y

XRL A, Y

RESULT: MOV Z, A

方法2:RL指令将符号位移入CY判断正负,RR指令将最低位移入CY判断奇偶

MOV A, X

CLR C

RLC A

JC NEG ;X为负,转至NEG

RRC A

RRC A

JNC EVEN1 MOV A, X

ADD A, Y SJMP RETULT

EVEN1: MOV A, X

ORL A, Y SJMP RETULT

NEG: RRC A,

; X为偶数,转至EVEN1

; X为正奇数,Z =X+Y

; X为正偶数,Z =X∨Y

RRC A

JNC EVEN2

MOV A, X

ANL A, Y ; X为负奇数,Z =X∧Y

SJMP RETULT

EVEN2: MOV A, X

XRL A, Y ; X为负偶数,Z =X⊕Y

RETULT: MOV Z, A

END

4. 把一个8位二进制数的各位用ASCII码表示之(例如,为0的位用30H表示,为1的位用31H表示等)。该数存放在内部RAM的byte单元中。变换后得到的8个ASCII码存放在外部RAM以buf开始的存储单元中,试编程实现。

ORG 0030H

14

MOV DPTR, #buf

MOV R0, # byte

MOV R7, #08H

MOV A, @ R0

CLR C

LOOP1 : RRC A

MOV R6, A

JC ONE

MOV A, #30H

SJMP LOOP2

ONE: MOV A, #31H

LOOP2 : MOVX @DPTR, A

INC DPTR

MOV A, R6

DJNZ R7, LOOP1

5. 编程实现运算式2 2 c a b 。假定a、b、c 3 个数分别存放于内部RAM 的

DA、DB、DC 单元中,另有平方运算子程序SQR 供调用。

ORG 0030H

MOV A, DA

PUSH ACC

ACALL SQR

POP ACC

MOV DC, A

MOV A, DB

PUSH ACC

ACALL SQR

POP ACC

ADD A, DC

MOV DC, A

15

SQR: POP ACC

MOV B, A

MUL AB

PUSH ACC

RET

END

6. 试编程实现两个ASCII码字符串是否相等。字符串的长度在内部RAM 41H单元中,第1个字符串的首地址为42H,第2个字符串的首地址为52H。如果两个字符串相等,则置内部RAM 40H单元为00H;否则置40H单元为FFH。

ORG 0030H

MOV R0, #42H

MOV R1, #52H

MOV R7, 41H

LOOP: MOV A, @R0

MOV 30H, @R1

CJNE A, 30H, LK

INC R0

INC R1

DJNZ R7, LOOP

MOV 40H, #00H

SJMP DD

LK: MOV 40H, #0FFH

DD: SJMP DD

7. 在外部RAM首地址为table的数据表中,有10字节数据。试编程实现将每个字节的最高位无条件置1。

ORG 0030H

MOV DPTR, #table

MOV R6, #10

LOOP: MOVX A, @DPTR

16

SETB ACC.7

MOVX @DPTR, A

INC DPTR

DJNZ R6, LOOP

第6 章 80C51 单片机的中断与定时

(一)填空题

1. 中断技术是解决资源竞争的有效方法,因此,可以说中断技术实质上是一种

资源(共享)技术。

2. 上电复位后,各中断优先级从高到低的次序为(外部中断0)、(定时器/计数

器0 中断)、(外部中断1)、(定时器/计数器1 中断)和(串行中断)。

3. 响应中断后,产生长调用指令LCALL,执行该指令的过程包括:首先把(PC)

的内容压入堆栈,以进行断点保护,然后把长调用指令的16 位地址送(PC),

使程序执行转向(ROM)中的中断地址区。

4. 当计数器产生计数溢出时,把定时器控制寄存器的TF0(TF1)位置1。对计

数溢出的处理,在中断方式时,该位作为(中断请求标志位)使用;在查询

方式时,该位作(查询状态位)使用。

5. 定时器1 工作于方式3 做波特率发生器使用时,若系统晶振频率为12 MHz,

可产生的最低波特率为(15.26 b/s),最高波特率为(1000000 b/s)。

对于12MHz 的晶振,一个机器周期为1s,定时器1 做波特率发生器使用时,

若工作于方式1,计数初值为0,则波特率最低,为6 1 65536 1.0 10 15.26bs

若计数初值为65535,则波特率最高,为1/(1*1.0*10e-6)=1000000b/s

6. 定时器0 工作于方式2 的计数方式,预置的计数初值为156,若通过引脚T0

输入周期为1ms 的脉冲,则定时器0 的定时时间为(100ms)。

7. 用于定时测试压力和温度的单片机应用系统,以定时器0 实现定时。压力超

限和温度超限的报警信号分别由INT0 和INT1输入,中断优先顺序为:压力

超限→温度超限→定时检测。为此,中断允许控制寄存器IE 最低3 位的状

态应是(111),中断优先级控制寄存器IP 最低3 位的状态应是(101)。

8. 可利用定时器来扩展外部中断源。若以定时器1扩展外部中断源,则该扩展外中断的中断请求输入端应为(T1)引脚,定时器1应取工作方式(2),预置的计数初值应为(0FFH),扩展外中断的入口地址应为(001BH)。

(二)单项选择题 1. 下列有关80C51中断优先级控制的叙述中错误的是(D)

(A)低优先级不能中断高优先级,但高优先级能中断低优先级

(B)同级中断不能嵌套

(C)同级中断请求按时间的先后顺序响应

(D)同一时刻,同级的多中断请求,将形成阻塞,系统无法响应

2. 80C51有两个定时器,下列有关这两个定时器级联定时问题的叙述中,正确的是(C)

(A)可以实现软件级联定时,而不能实现硬件级联定时

(B)可以实现硬件级联定时,而不能实现软件级联定时

(C)软件级联定时和硬件级联定时都可以实现

(D)软件级联定时和硬件级联定时都不能实现

3. 在工作方式0下,计数器由TH的全部8位和TL的低5位组成,因此,其计数范围是(A)

(A)1 ~ 8192 (B)0 ~ 8191 (C)0 ~ 8192 (D)1 ~ 4096

4. 对于由80C51构成的单片机应用系统,中断响应并自动生成长调用指令LCALL后,应(B)

(A)转向外部程序存储器去执行中断服务程序

(B)转向内部程序存储器去执行中断服务程序

(C)转向外部数据存储器去执行中断服务程序

(D)转向内部数据存储器去执行中断服务程序

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

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

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

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

(D)当前指令是“MOV A, Rn” 指令

6. 下列条件中,不是中断响应必要条件的是(C)

(A)TCON 或SCON 寄存器中相关的中断标志位置1

(B)IE 寄存器中相关的中断允许位置1

(C)IP 寄存器中相关位置1

(D)中断请求发生在指令周期的最后一个机器周期

7. 在单片机的下列功能或操作中,不使用中断方法的是(D)

(A)串行数据传送操作 (B)实时处理

(C)故障处理 (D)存储器读/写操作

第6 章 单片机并行存储器扩展

(一)填空题

1. 使用8KB×8 位的RAM 芯片,用译码法扩展64KB×8 位的外部数据存储器,

需要(8)片存储芯片,共需使用(16)条地址线,其中(13)条用于存储

单元选择,(3)条用于芯片选择。

2. 三态缓冲器的三态分别是(低电平)、(高电平)和(高阻抗)。

3. 80C51 单片机系统整个存储空间由4 部分组成,分别为(256)个地址单元

的内部(数据)存储器,(4KB)个地址单元的内部(程序)存储器,(64KB)

个地址单元的外部(数据)存储器,(60KB)个地址单元的外部(程序)存

储器。

4. 在80C51 单片机系统中,为外扩展存储器准备了(16)条地址线,其中低位

地址线由(P0 口)提供,高位地址线由(P2 口)提供。

5. 在80C51 单片机系统中,存储器并行外扩展涉及的控制信号有(ALE)、

(WR )、(RD )、( PSEN )和(CE),其中用于分离低8 位地址和数据的

控制信号是(ALE),它的频率是晶振频率的(6)分之一。

6. 起止地址为0000H ~ 3FFFH 的外扩展存储器芯片的容量是(16KB)。若外扩

展存储器芯片的容量为2KB,起始地址为3000H,则终止地址应为(37FFH)。

7. 与微型机相比,单片机必须具有足够容量的程序存储器是因为它没有(外

19

存)。

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

引脚端提供信号。

9. 由一片80C51 和一片2716 组成的单片机最小系统。若2716 片选信号CE 接

地,则该存储芯片连接共需(11)条地址线。除数据线外,系统中连接的信

号线只有( PSEN )和(ALE)。

(二)单项选择题

1. 下列有关单片机程序存储器的论述中,错误的是(D)

(A)用户程序保存在程序存储器中

(B)断电后程序存储器仍能保存程序

(C)对于程序存储器只使用MOVC 一种指令

(D)执行程序需要使用MOVC 指令从程序存储器中逐条读出指令

2. 下列有关单片机数据存储器的论述中,错误的是(A)

(A)数据存储器只使用MOV 指令进行读/写

(B)堆栈在数据存储器中开辟

(C)数据存储器只用于保存临时数据

(D)专用寄存器也是数据存储器的一部分

3. 在单片机系统中,1KB 表示的二进制位数是(D)

(A)1000 (B)8×1000 (C)1024 (D)8×1024

4. 在下列信号中,不是供外扩展程序存储器使用的是(D)

(A) PSEN (B)EA (C)ALE (D)WR

5. RAM 是随机存储器的意思,随机存储器的准确含义是(B)

(A)存储器的各存储单元的存取时间相等

(B)可以在任何时刻随机读/写存储器内各存储单元

(C)随机表示既可读又可写

(D)随机是易失的意思,因为随机存储器具有易失的特点

6. 若在系统中只扩展一片Intel 2732(4K×8 位),除应使用P0 口的8 条口线外,

20

至少还应使用P2 口的口线(A)

(A)4 条 (B)5 条 (C)6 条 (D)7 条

7. 下列叙述中,不属于单片机存储器系统特点的是(D)

(A)程序和数据两种类型的存储器同时存在

(B)芯片内外存储器同时存在

(C)扩展数据存储器与片内数据存储空间重叠

(D)扩展程序存储器与片内程序存储空间重叠

8. 在80C51 单片机系统中,为解决内外程序存储器衔接问题所使用的信号是

(A)

(A)EA (B) PSEN (C)ALE (D)CE

第7 章 单片机并行I/O 扩展

(一)填空题

1. 80C51 单片机I/O 扩展占据的是(外部数据)存储器的地址空间,因此,其

扩展连接只涉及(ALE)、(WR )和(RD )3 个控制信号。

2. 在单片机中,为实现数据的I/O 传送,可使用3 种控制方式,即(无条件)

方式、(查询)方式和(中断)方式。其中效率较高的是(中断方式)。

3. 简单输入口扩展是为了实现输入数据的(缓冲)功能,而输出口扩展是为了

实现输出数据的(锁存)功能。

第8 章 80C51 单片机串行通信

(一)填空题

1. 异步串行数据通信的帧格式由(起始)位、(数据)位、(奇偶校验)位、(停

止)位组成。若串行异步通信每帧为11 位,串行口每秒传送250 个字符,

则波特率应为(2750 b/s)。

2. 串行通信有(单工)、(双工)和(半双工)共3 种数据通路形式。

3. 串行接口电路的主要功能是(串行)化和(反串行)化,把帧中格式信息滤

21

除而保留数据位的操作是(反串行)化。

4. 串行异步通信,传送速率为2400 b/s,每帧包含1 个起始位、7 个数据位、1

个奇偶校验位和1 个停止位,则每秒传送字符数为(240 个)。

5. 80C51 串行口使用定时器1 作波特率发生器时,应定义为工作方式2,即(8

位自动加载)方式。假定晶振频率为12MHz,则可设定的波特率范围是(122

b/s)~(62500 b/s)。

分析:定时器1 工作方式2 时的波特率为:

SMOD

SMOD osc 2

2 32 1

32 12 256

f X

波特率定时器溢出率

当SMOD=0,X=0 时,

6 1 12 10

122

32 12 256

b s

波特率(最小波特率)

当SMOD=1,X=255 时,

6 2 12 10

62500

32 12 1

b s

波特率(最大波特率)

6. 在80C51 串行通信中,方式(0)和方式(2)的波特率是固定的,波特率的

大小只与(晶振)频率有关。而方式(1)和方式(3)的波特率是可变或可

设置的,波特率大小与定时器(T1)的(溢出)率有关。

(二)单项选择题

1. 下列特点中,不是串行数据传送所具有的是(A)

(A)速度快 (B)成本低

(C)传送线路简单 (D)适用于长距离通信

2. 下列有关串行同步通信与异步通信的比较中,错误的是(B)

(A)它们采用的是相同的数据传输方式,但采用不同的数据传输格式

(B)它们采用的是相同的数据传输格式,但采用不同的数据传输方式

(C)同步方式适用于大批量数据传输,而异步方式则适用于小批量数据传

(D)同步方式对通信双方同步的要求高,实现难度大,而异步方式的要求

则相对较低

3. 调制解调器的功能是(A)

(A)数字信号与模拟信号的转换

22

(B)电平信号与频率信号的转换

(C)串行数据与并行数据的转换

(D)基带传输方式与频带传输方式的转换 4. 帧格式为1个起始位、8个数据位和1个停止位的异步串行通信方式是(B)

(A)方式0 (B)方式1 (C)方式2 (D)方式3 5. 通过串行口发送或接收数据时,

在程序中应使用(A)

(A)MOV指令 (B)MOVX指令 (C)MOVC指令 (D)SWAP指令 6. 下列有关第9数据位的说明中,错误的是(C)

(A)第9数据位功能可由用户定义

(B)发送数据的第9数据位内容在SCON寄存器的TB8位中预先准备好

(C)帧发送时使用指令把TB8位的状态送入发送SBUF中

(D)接收到的第9数据位送SCON寄存器的RB8位中保存 7. 下列有关串行通信的说明中,错误的是(A)

(A)80C51串行口只有异步方式而无同步方式,因此,只能进行串行异步通信

(B)80C51串行口发送和接收使用同一个数据缓冲寄存器SBUF

(C)双机通信时要求两机的波特率相同

(D)偶校验是指给校验位写入一个0或1,以使得数据位和校验位中1的个数为偶数__

因篇幅问题不能全部显示,请点此查看更多更全内容