《单片机基础》练习题及答案 下载本文

单片机基础(第3版)

第1章 计算机基础知识

(一)填空题

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.0?P1.1?P1.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=(10H?P1.0)?(11H?CY)

MOV C, P1.0

ORL MOV ORL ANL MOV C, /10H F0, C C, 11H C, F0 D, C

(2)E=ACC.2?P2.7?ACC.1?P2.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 ; 将m单元中的BCD数送入累加器A ANL A, #0FH ; 把m单元的高4位清0 SWAP A ; 将m单元中的BCD数移入高4位 MOV @R0, A ; m单元高4位为BCD数,低4位为0 INC R0 ; 指向m+1单元 MOV A, @R0 ; 将m+1单元中的BCD数送入累加器A ANL A, #0FH ; 把m+1单元的高4位清0 DEC R0 ; 指向m单元 ORL A, @R0 ; 将和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