范文一:单片机第三版试题8
试题 8
一、填空
1. 执行 MOVX @R1, A 指令时,伴随着 ( ) 控制信号有效。
2. AT89S51单片机复位时, PC 指针的内容为() , 4个端口寄存器 P0~ P3中的内容 为() 。
3. PSW 寄存器中的 A C 标志位,称为 ( ) 标志位,是用于()运算时, 用作() 。
4. AT89S51单片机采用外部时钟电路时, ( )引脚应悬空。外部振荡器输出的时钟 信号接()引脚。
5.设计一个以 AT89S51单片机应用系统,如果仅使用其内部 4KB 闪存作为程序存储器, 则其 () 引脚应该接() 。
6.当 AT89S51单片机复位后,中断优先级最高的中断源是() 。
7. 已知 8段共阳极 LED 数码管要显示字符 “ 5” (a段为最低位 ) , 此时的段码为 () 。
8.在 R7初值为 FF 时, DJNZ R7, rel 指令将循环执行()次。
9.某数据存储器 62128芯片的地址线为()条 , 那么它的存储容量为() 。 假设 62128的起始地址为 6000H, 它的末地址为 () 。
10.当时钟频率为 12MHz 时,定时器 T0方式 2下的最大定时时间为 () 。
11. 若 ()中的内容为 68H ,那么 P 标志位为 () 。
12. () 单片机片内有 8K 字节的闪烁存储器,有()字节的片内 RAM 单元。 13.以 AT89S51为核心的单片机最小系统,除了要有单片机外,还要有()电路和 ()电路。
14.当 AT89S51执行 MOVC A, @A+DPTR指令时,伴随着 () 控制信号有效。
15. AT89S51单片机跳转指令 LJMP 的跳转范围是 () , AJMP 的跳转范围是 () 。 16. AT89S51单片机与慢速外设进行数据传输时,最佳的数传方式是采用() 。 17.单片机从调用的子程序返回时,必须执行的返回指令是() 。
18.AT89S51单片机控制 LCD 显示英文字符或数字字符时,要把欲显示字符的()码 送给 LCD 控制模块。
19.如果定时器的启动和停止要由两个信号 TRx (x=0,1)和 INT x (x=0,1)来共同控制, 此时寄存器 TMOD 中的 GATEx (x=0,1)位必须为() 。
20.串行口方式 3接收数据时, ()寄存器的()位必须为 1,接收到的第 9位数据进入到该寄存器的()位中。
21. D/A转换器的两个最重要的技术指标为()和() 。
22.某 10位 A/D转换器的转换电压范围为 0~ 10V, 其分辨率为() mV 。
23. AT89S51单片机访问片外数据存储器的寻址方式是() 。
24.当用串行口进行串行通信时,为减小波特率误差,使用的时钟频率为() MHz 。 二、判断,在后面的括号中填入“√”或“×”
1.单片机扩展 I/O接口芯片,要占用片外数据存储器的地址资源。 ()
2.单片机的功能侧重于测量和控制, DSP 侧重于高速、复杂运算。 ()
3. AT89S51单片机进行串行通讯时,定时器方式 2能产生比方式 1更低的波特率。 ()
4. 同为高中断优先级, 外部中断 0能打断正在执行的外部中断 1的中断服务程序。 ()
5.在 AT89S51单片机的汇编语言中,操作码是唯一不能空缺的部分。 ()
6.软件延时程序比定时器的定时更精确。 ()
7.中断服务子程序可以直接调用。 ()
8.特殊功能寄存器 TCON ,仅与定时器 /计数器的控制相关。 ()
9. LED 数码管工作于动态显示方式时,同一时间只有一个数码管被点亮。 ()
10.数据指针 DPTR 只用于访问数据存储器。 ()
11.如果只有一路模拟量输出, DAC0832可以采用单缓冲方式,如果有多路模拟量输出, DAC0832则必须采用双缓冲方式。 ()
12. AT89S51单片机的 P1口如果作为输入端口使用时,必须先向 P1口写入 FFH 。 () 13.并行接口芯片 82C55的方式 0是无条件的输入输出方式。 ()
14.指令中直接给出的操作数称为直接寻址。 ()
15. AT89S51片内 RAM 的位寻址区,只能进行位寻址,不能进行字节寻址。 () 16. “ INC A”和“ DEC A”指令不影响程序状态字 PSW 中的任何标志。 ()
三、简答
1. 在中断服务程序中为什么需要保护现场和恢复现场?
2. AT89S51单片机定时器 T0的方式 2是多少位的定时 /计数器?简述其工作过程。
四、 AT89S51单片机与 3位 8段共阳极 LED 相接,静态显示。
1.分别写出显示字符“ 1. ” 、 “ 2” 、 “ 3”的段码,注:段码的最低位为“ a ”段,段码的 最高位为“ dp ”段;
2.已知 82C55的 PA 口、 PB 口和 PC 口的地址分别为 FF7CH 、 FF7DH 、 FF7EH ,且 82C55的 这 3个端口均已被编写完毕的初始化程序初始化为方式 0输出,请编写出使 3位 LED 共 阳极显示器从左至右显示“ 1.23”的程序段。
a b c d e f g ● dp
5V
五、 AT89S51单片机通过 ADC0809进行模数转换,采用中断控制方式,请回答:
1.标出图中①、②、③所对应的引脚符号;
2.填写程序或注释中的空白部分 a ~f ;
3.程序中的“ #addr”为模拟输入的端口地址,当单片机分别对“ IN0” 、 “ IN3”和“ IN7” 进行模数转换时,写出对应的“ #addr”的取值(注意:地址线未用到的位为 1) 。
ORG 0000H
AJMP MAIN
ORG 0013H ; a 的中断入口地址
b ;读 A/D转换结果
RETI
ORG 0100H
MAIN :SETB IT1 ; c 触发方式选择
SETB d ;总中断允许
SETB e ;允许中断
MOV DPTR , #addr ;指向某一模拟输入通道
f ;启动 A/D转换
SJMP $ ;等待中断
六、 请回答:
1.下图中单片机外部扩展的程序存储器和数据存储器容量各是多少? 2.三片存储器芯 片的地址范围分别是多少? (地址线未用到的位为 1)
3.请编写程序,将内部 RAM 40H~4FH 中的内容送入 1# 6264的前 16个单元中;
范文二:单片机第三版课后答案 单片机基础第三版课后答案器
单片机基础(第3版)
第1章 计算机基础知识
(一)填空题
1. 十进制数14对应的二进制数表示为(1110B),十六进制数表示为(0EH)。
十进制数-100的补码为(9CH),+100的补码为(64H)。
2. 在一个非零的无符号二进制整数的末尾加两个0后,形成一个新的无符号二
进制整数,则新数是原数的(4)倍。
3. 8位无符号二进制数能表示的最大十进制数是(255)。带符号二进制数
11001101转换成十进制数是(-51)。
4. 可以将各种不同类型数据转换为计算机能处理的形式
1
并输送到计算机中去
的设备统称为(输入设备)。
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 (C)-127 ~ +128 2.
下列等式中,正确的是(B)
(A)1 KB = 1024×1024 B (B)1 MB = 1024×1024
B
2
(B)-128 ~ +128 (D)-128 ~ +127
(C)1 KB = 1024 M B 3. 程序与软件的区别是(C)
(A)程序小而软件大 (C)软件包括程序
(D)1 MB = 1024 B
(B)程序便宜而软件昂贵 (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. 有
3
一个数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)个振荡脉冲周期。
4
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)
5
(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)为程序设计提供方便 7. 下列叙述中正确的是(D)
(D)减小程序长度
(A)SP内装的是堆栈栈顶单元的内容
(B)在中断服务程序中没有PUSH和POP指令,说明此次中断操作与堆栈
无关
(C)在单片机中配合实现“程序存储自动执行”的寄存器是累加器 (D)两数相加后,若A中数据为66H,则PSW
6
中最低位的状态为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.
MOV C, P1.0 ANL ANL
C, P1.1 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,
7
请按要求填写各条指令
的执行结果(每条指令均按已给定的原始数据进行操作)。
XCH XCH
A, R0 A, 30H
A=(30H),R0=(7AH) A=(0A5H)
XCH A, @R0
A=(0A5H) A=(75H) A=(0A7H)
A=(0AAH),CY=(0),OV=(1) A=( 1FH ),CY=(1),OV=(0) A=(0AAH),CY=(0),OV=(1) A=( 20H ),CY=(1),OV=(0) A=(0D4H),CY=(1),OV=(1) A=( 49H ),CY=(0),OV=(0)
XCHD A, @R0 SWAP A ADD ADD ADD
A, R0 A, 30H A, #30H
ADDC A, 30H SUBB A, 30H SUBB A, #30H
(二)单项选择题
1. 下列指令或指令序列中,不能实现PSW内容送A的是(C)
(A)MOV A, PSW (C)MOV R0, 0D0H
MOV A,@R0
8
(B)MOV A, 0D0H (D)PUSH PSW
POP ACC
2. 在相对寻址方式中,“相对”两字是指相对于(C)
(A)地址偏移量rel
(B)当前指令的首地址 (D)DPTR值
(C)下一条指令的首地址
3. 下列指令或指令序列中,能将外部数据存储器3355H单元内容传送给A的
是(B)
(A)MOVX A, 3355H
(B)MOV DPTR, #3355H
MOVX A, @ DPTR
(C)MOV P0, #33H
(D)MOV P2, #33H
MOV R2, #55H MOVX A, @ R2
MOV R0, #55H MOVX A, @ R0
4. 对程序存储器的读操作,只能使用(D)
9
(A)MOV 指令
(B)PUSH 指令 (D)MOVC指令
(C)MOV X指令
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
10
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
C, /10H
MOV F0, C ORL C, 11H ANL
C, F0
MOV 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
11
0000H
; R0指向20H单元 ; 4个单元 ; 写入
MOV R0, #20H
MOV R1, #04H
LOOP: MOV @R0, #0F0H
INC
R0
DJNZ R1, LOOP END
; 循环4次
4. 在m和m+1单元中存有两个BCD数,将他们合并到m单元中,编写程序
完成。
ORG
0030H
; 将m单元中的BCD数送入累加器A ; 把m单元的高4位清0
; 将m单元中的BCD数移入高4位 ; m单元高4位为BCD数,低4位为0 ; 指向m+1单元
12
; 将m+1单元中的BCD数送入累加器A ; 把m+1单元的高4位清0 ; 指向m单元
; 将和m+1单元和m单元内容合并 ; 合并后结果送m单元
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
MOV @R0, A END
5. 将内部RAM中从data单元开始的10个无符号数相加,其和送sum单元。
假定相加结果小于255。编写程序完成。
ORG
13
0030H
MOV R0, #10 ; 给 R0 置计数器初值 MOV R1, # data CLR
; 数据块首址送R1
A ; A清零
LOOP: ADD
INC
A, @R1 ; 加一个数
R1 ; 修改地址,指向下一个数
; R0 减 1,不为零循环
DJNZ R0, LOOP
MOV sum, A ; 存 10 个数相加和 END
6. 假定8位二进制带符号数存于R0中,要求编写一个求补(取反)程序,所
得补码放入R1中。
分析:对存于R0中的二进制带符号数,如果是正数,则将其变成绝对值相等的负数(用补码表示);如果是负数(用补码表示),则将其变成绝对值相等的正数。
ORG
0030H
; 将带符号数送入A
14
MOV A, R0 CPL ADD
A A, #01H
; 末位加 1 ; 补码存入R1
MOV R1, A END
第4章 单片机汇编语言程序设计
(一)填空题
1. 假定A=40H,R1=23H,(40H)= 05H。执行以下两条指令后,A=(25H),
R1=(40H),(40H)=(03H)。
XCH
A, R1
; A=23H,R1=40H ; A=20H,(40H)=03H
XCHD A, @R1
2. 假定80C51的晶振频率为6 MHz,执行下列程序后,在P1.1引脚产生的方
波宽度为(5.804ms) START: SETB P1.1 DL: DL0: DL1:
; P1.1置1(1周期) ; 30H置初值(1周期) ; 31H置初值(1周期)
; 31H减1,不为0重复执行(2周期) ; 30H减1,不为
15
0转DL0(2周期)
MOV 30H, #03H MOV 31H, #0F0H DJNZ 31H, DL1
DJNZ 30H, DL0
CPL P1.1
; P1.1取反(1周期) ; 转DL(2周期)
SJMP DL
方波宽度
={[(2*15*16+2+1)*3]+[(2*15*16+2+1)*3+1+2+1]}*2=5804μs
3. 下列程序中,X、Y和Z为输入的8位无符号二进制数,F为输出的逻辑运
算结果。试画出该程序所模拟的组合逻辑电路。
MOV A, X ANL
A, Y
MOV R1, A MOV A, Y XRL CPL ORL
A, Z A A, R1
MOV F, A
X
Y
F
Z
16
4. 分析下列跳转程序,程序中A与30H单元中的数都是符号数,说明当(A=
(30H))时转向LOOP1,当(A>(30H))时转向LOOP2,当(AMOV R0, A ANL
A, #80H
; R0?A
JNZ NEG ; AMOV A, 30H ANL JNZ
A, #80H LOOP2
; A?0,(30H) SJMP COMP
NEG: MOV A, 30H
ANL JZ
A, #80H LOOP3
; ACOMP: MOV A, R0
CJNE A, 30H, NEXT SJMP LOOP1
NEXT: JNC
JC
LOOP2 LOOP3
17
; A?(30H),转NEXT ; A=(30H),转LOOP1 ; A,(30H),转LOOP2 ; A,(30H),转LOOP3
综上分析可知,当A=(30H)时转向LOOP1,A>(30H)时转向LOOP2,A5. 假定80C51的晶振频率为6 MHz,下列程序的执行时间为(30.696ms)。已
知程序中前2条指令机器周期数为1,后4条指令机器周期数为2。
MOV R3, #15
DL1: DL2:
MOV R4, #255 MOV P1, R3 DJNZ R4, DL2 DJNZ R3,
DL1
RET
1周期 1周期 2周期 2周期 2周期 2周期
执行时间:T={[(2+2)*255+2+1]*15+2+1}*2=30696 s
(二)编程题
1. 把长度为10H的字符串从内部RAM的输入缓冲区inbuf向位于外部RAM的
输出缓冲区outbuf传送,一直进行到遇见回车或整个字符串传送完毕,试编程实现。
18
ORG 0030H
MOV R0, #inbuf MOV DPTR, #outbuf MOV R4, #10H
LOOP:
MOV A, @R0
; 从内部RAM取数 ; 是否为回车符CR
; 是回车符,则转STOP,停止传送 ; 不是回车符,则传送到外部RAM
CJNE A,#0DH, LL SJMP STOP
LL:
MOVX @ DPTR, A INC INC
R0 DPTR
DJNZ R4, LOOP
STOP:
; 沒传送完则循环
SJMP $
2. 内部RAM从list单元开始存放一正数表,表中之数作无序排列,并以,1
作结束标志。编程实现找出表中最小数。
分析:从list+1单元开始判断其中的数是否为-1,将比较
19
得到的小数放入累加器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 $
20
;取最小数
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 JNZ
A, #80H ; 判断X正负 NEG
; 若X为负,转NEG ; X为正 ; 判断X奇偶
; 若X为偶数,转EVEN1
MOV A, X ANL JZ
A, #01H EVEN1
MOV A, X
21
ADD
A, Y
; 若X为正奇数,Z,X,Y
SJMP RESULT MOV A, X ORL
A, Y
; 若X为正偶数,Z,X?Y
EVEN1:
SJMP RESULT MOV A, X ANL
; X为负 ; 判断X奇偶
; 若X为偶数,转EVEN2
NEG:
A, #01H EVEN2
JZ
MOV A, X ANL
A, Y
; 若X为负奇数,Z,X?Y
22
SJMP RESULT MOV A, X XRL
A, Y
; 若X为负偶数,Z,X?Y
EVEN2:
RESULT: MOV Z, A
方法2:RL指令将符号位移入CY判断正负,RR指令将最低位移入CY判断奇偶
MOV A, X CLR
C
RLC A JC
NEG
;X为负,转至NEG
RRC A RRC A
; X为偶数,转至EVEN1
JNC EVEN1 MOV A, X ADD
A, Y
23
; X为正奇数,Z ,X,Y
SJMP RETULT
EVEN1:
MOV A, X ORL A, Y
; X为正偶数,Z ,X?Y
SJMP RETULT
NEG:
RRC A, RRC A JNC EVEN2 MOV A, X ANL
A, Y
; X为负奇数,Z ,X?Y
SJMP RETULT
EVEN2:
MOV A, X XRL A, Y
RETULT:
4. 把一个8位二进制数的各位用ASCII码表示之(例如,为0的位用30H表示,
为1的位用31H表示等)。该数存放在内部RAM的byte单元中。变换后得到的8个ASCII码存放在外部RAM以
24
buf开始的存储单元中,试编程实现。
ORG
; X为负偶数,Z ,X?Y
MOV Z, A END
0030H
MOV DPTR, #buf MOV R0, # byte MOV R7, #08H MOV
A, @ R0 CLR
LOOP1 :
RRC
C A
MOV R6, A JC
ONE
MOV A, #30H SJMP LOOP2
ONE: LOOP2 :
MOV A, #31H MOVX @DPTR, A INC
DPTR
MOV A, R6 DJNZ R7, LOOP1
5. 编程实现运算式c=a2+b2。假定a、b、c 3个数分别存放于内部RAM的
25
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
ADD
ACC A, DC
MOV DC, A
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
26
MOV R0, #42H MOV R1, #52H MOV R7, 41H
LOOP: MOV A, @R0
MOV 30H, @R1 CJNE A, 30H, LK INC INC
R0 R1
DJNZ R7, LOOP MOV 40H, #00H SJMP DD
LK: DD:
7. 在外部RAM首地址为table的数据表中,有10字节数
据。试编程实现将每
个字节的最高位无条件置1。
ORG
0030H DPTR, #table R6, #10 A, @DPTR
MOV 40H, #0FFH SJMP DD
MOV MOV
LOOP: MOVX
SETB MOVX INC
ACC.7 @DPTR, A DPTR R6, LOOP
DJNZ
第5章 80C51单片机的中断与定时
(一)填空题
27
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的晶振,一个机器周期为1μs,定时器1做波特率发生器使用时,若工作于方式1,计数初值为0,则波特率最低,为(65536?1.0?10-6)=15.26b 若计数初值为65535,则波特率最高,为1?1.0?10-6)=1000000b
28
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有两个定时器,下列有关这两个定时器
29
级联定时问题的叙述中,正确
的是(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指令,且正处于取指机器周期
30
(D)当前指令是“MOV A, Rn” 指令 6. 下列条件中,不是中断响应必要条件的是(C)
(A)TCON或SCON寄存器中相关的中断标志位置1 (B)IE寄存器中相关的中断允许位置1 (C)IP寄存器中相关位置1
(D)中断请求发生在指令周期的最后一个机器周期 7. 在单片机的下列功能或操作中,不使用中断方法的是(D)
(A)串行数据传送操作 (C)故障处理
(B)实时处理 (D)存储器读/写操作
第6章 单片机并行存储器扩展
(一)填空题
1. 使用8KB×8位的RAM芯片,用译码法扩展64KB×8位的外部数据存储器,
需要(8)片存储芯片,共需使用(16)条地址线,其中(13)条用于存储单元选择,(3)条用于芯片选择。
2. 三态缓冲器的三态分别是(低电平)、(高电平)和(高阻抗)。
3. 80C51单片机系统整个存储空间由4部分组成,分别为(256)个地址单元
的内部(数据)存储器,(4KB)个地址单元的内部(程序)存储器,(64KB)个地址单元的外部(数据)存储器,(60KB)
31
个地址单元的外部(程序)存储器。
4. 在80C51单片机系统中,为外扩展存储器准备了(16)条地址线,其中低位
地址线由(P0口)提供,高位地址线由(P2口)提供。
5. 在80C51单片机系统中,存储器并行外扩展涉及的控制信号有(ALE)、
、
、
,其中用于分离低8位地址和数据的
控制信号是(ALE),它的频率是晶振频率的(6)分之一。
6. 起止地址为0000H ~ 3FFFH的外扩展存储器芯片的容量是(16KB)。若外扩
展存储器芯片的容量为2KB,起始地址为3000H,则终止地址应为(37FFH)。 7. 与微型机相比,单片机必须具有足够容量的程序存储器是因为它没有(外
存)。
8. 在存储器扩展中,无论是线选法还是译码法,最终都是为扩展芯片的(片选)
引脚端提供信号。
9. 由一片80C51和一片2716组成的单片机最小系统。若2716片选信号CE接
地,则该存储芯片连接共需(11)条地址线。除数据线外,
32
系统中连接的信
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
33
(B)EA
(C)ALE
(D)WR
5. RAM是随机存储器的意思,随机存储器的准确含义是(B)
(A)存储器的各存储单元的存取时间相等
(B)可以在任何时刻随机读/写存储器内各存储单元 (C)随机表示既可读又可写
(D)随机是易失的意思,因为随机存储器具有易失的特点
6. 若在系统中只扩展一片Intel 2732(4K×8位),除应使用P0口的8条口线外,
至少还应使用P2口的口线(A) (A)4条
(B)5条
(C)6条
(D)7条
7. 下列叙述中,不属于单片机存储器系统特点的是(D)
(A)程序和数据两种类型的存储器同时存在 (B)芯片内外存储器同时存在
(C)扩展数据存储器与片内数据存储空间重叠 (D)扩
34
展程序存储器与片内程序存储空间重叠
8. 在80C51单片机系统中,为解决内外程序存储器衔接问题所使用的信号是
(A) (A)EA
(B)PSEN
(C)ALE
(D)CE
第7章 单片机并行I/O扩展
(一)填空题
1. 80C51单片机I/O扩展占据的是(外部数据)存储器的地址空间,因此,其
扩展连接只涉及(ALE)、
3个控制信号。
2. 在单片机中,为实现数据的I/O传送,可使用3种控制方式,即(无条件)
方式、(查询)方式和(中断)方式。其中效率较高的是(中断方式)。 3. 简单输入口扩展是为了实现输入数据的(缓冲)功能,而输出口扩展是为了
实现输出数据的(锁存)功能。
第8章 80C51单片机串行通信
35
(一)填空题
1. 异步串行数据通信的帧格式由(起始)位、(数据)位、(奇偶校验)位、(停
止)位组成。若串行异步通信每帧为11位,串行口每秒传送250个字符,则波特率应为(2750 b/s)。
2. 串行通信有(单工)、(双工)和(半双工)共3种数据通路形式。 3. 串行接口电路的主要功能是(串行)化和(反串行)化,把帧中格式信息滤
除而保留数据位的操作是(反串行)化。
4. 串行异步通信,传送速率为2400 b/s,每帧包含1个起始位、7个数据位、1
个奇偶校验位和1个停止位,则每秒传送字符数为(240个)。
5. 80C51串行口使用定时器1作波特率发生器时,应定义为工作方式2,即(8
位自动加载)方式。假定晶振频率为12MHz,则可设定的波特率范围是(122 b/s)~(62500 b/s)。
分析:定时器1工作方式2时的波特率为:
波特率=(2SMODfosc2SMOD
)?(定时器1溢出率)=?3212?256-X112?106
=122 s(最小波特率) 当SMOD=0,X=0时, 波特率=?3212?256
36
212?106
=62500 s(最大波特率) 当SMOD=1,X=255时, 波特率=?3212?1
6. 在80C51串行通信中,方式(0)和方式(2)的波特率是固定的,波特率的
大小只与(晶振)频率有关。而方式(1)和方式(3)的波特率是可变或可设置的,波特率大小与定时器(T1)的(溢出)率有关。
(二)单项选择题 1. 下列特点中,不是串行数据传送所具有的是(A)
(A)速度快
(B)成本低 (D)适用于长距离通信 (C)传送线路简单
2. 下列有关串行同步通信与异步通信的比较中,错误的是(B)
(A)它们采用的是相同的数据传输方式,但采用不同的数据传输格式
(B)它们采用的是相同的数据传输格式,但采用不同的数据传输方式
(C)同步方式适用于大批量数据传输,而异步方式则适用于小批量数据传
输
37
(D)同步方式对通信双方同步的要求高,实现难度大,而异步方式的要求
则相对较低
3. 调制解调器的功能是(A)
(A)数字信号与模拟信号的转换
(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位中保存
38
7. 下列有关串行通信的说明中,错误的是(A)
(A)80C51串行口只有异步方式而无同步方式,因此,只能进行串行异步
通信
(B)80C51串行口发送和接收使用同一个数据缓冲寄存器SBUF
(C)双机通信时要求两机的波特率相同
(D)偶校验是指给校验位写入一个0或1,以使得数据位和校验位中1的
个数为偶数
中断源:产生中断的请求源称为中断源。
80C51的中断系统具有5个中断源:2个外部中断、2个定时器中断、1个串行中断。 中断向量:中断服务程序的入口地址
单片机关于中断的控制包括四项:中断允许控制 中断请求控制 中断优先控制 外中断触发方式控制
涉及四个特殊功能寄存器 中断允许控制寄存器IE
定时器控制寄存器TCON 串行口控制寄存器SCON 中断优先级控制寄存器IP
80C51具有两个优先级,中断嵌套只能一层,其原则是:
高优先级中断请求可以打断低优先级的中断服务,进行中
39
断嵌套;
同优先级的中断不能嵌套;
低优先级中断请求不能对高优先级的中断进行嵌套。
中断响应过程
1. 外部中断请求采样 2. 中断查询 3. 中断响应 4. 中断响应的快慢
中断优先优先级定义原则:中断的轻重缓急程度 中断设备的工作速度 中断处理的工作量 中断请求发生的频繁程度
中断优先原则在中断响应时的体现:
当高、低优先级中断请求同时出现时,高优先级中断请求被响应;
如果同级的多个中断请求同时出现,则按CPU查询次序确定哪个中断请求被响应。查询次序是: 外部中断定时器0中断外部中断定时器1中断串行中断
单片机指令系统共有7种寻址方式。寄存器寻址 直接寻址 寄存器间接寻址 立即寻址 变址寻址
位寻址 相对寻址
40
单片机的特点:1优异的性能价格比 2高集成度,体积小,高可靠性 3易扩展控制功能强
4 单片机方便实现多机和分布式控制系统
单片机内部逻辑结构:1中央处理器cpu 2内部数据存储器RAM 3内部程序存储器ROM
4定时器/计数器 5并行I/O口 6串行口 7中断控制电路 8时钟电路 9位处理器 10 内部总线
百度搜索“就爱阅读”,专业资料,生活学习,尽在就爱阅读网92to.com,您的在线图书馆
41
范文三:单片机第三版期末考试重点
复习例题
第二章
一、 判断题
1、用户构建单片机应用系统,只能使用芯片提供的信号引脚。(对 ) 2、程序计数器PC不能为用户使用,因此它就没有地址。(对) 3、内部RAM的位寻址区,只能供位寻址使用而不能供字节寻址使用(错) 4、对单片机的复位操作就是初始化操作。(对)
5、MCS-51单片机内部高128个字节特殊寄存器区都是可位寻址区。(错) 二、 填空题
1、 MCS-51单片机采用12MHz晶振时,ALE引脚脉冲频率为_2MHz___。
2、若由程序设定RS1、RS0=11,则工作寄存器R0-R7的直接地址为
_18H-1FH___。
3、 累加器A中的数据为01110010B,则PSW中的P=_0_______。
4、MCS—5l单片机的堆栈区只可设置在 便笺区 ,堆栈寄存器SP是 8 位寄存器。 三、 选择题
1、对程序计数器PC的操作( A )
A、是自动进行的。 B、是通过传送指令进行的。
C、是通过加1指令进行的。 D、是通过减1指令进行的。 2、以下运算中对溢出标志位OV没有影响的是(A )。
A、逻辑运算 B、符号数加减法运算 C、乘法运算 D、除法运算 3、以下有关PC和DPTR的结论中错误的是( C )
A、 DPTR是可以访问的而PC不能访问。B、它们都是16位的寄存器
C、它们都具有自动加1功能 D、DPTR可分为2个8位寄存器用而PC不能。 4、PC的当前值是( C )
A、当前指令前一条指令的地址 B、当前正在执行指令的地址 C、下一条指令的地址
?5、假定设置堆栈指针SP的值为37H,在进行子程序调用时把断点地址进栈保护后,SP的值为(D )
A、36H B、37H C、38H D、39H
6、在8051中,可使用的堆栈最大深度为( A )
A、80个单元 B、32个单元 C、128个单元 D、8个单元
7、在MCS-51中(C )
A、具有独立的专用的地址线 B、由P0口和P1口的口线作地址线
C、由P0口和P2口的口线作地址线 D、由P1口和P2口的口线作地址线
第三章
一、判断题
1. 判断以下各条指令是否正确(LL1和PROC为符号地址)
(1)MOVX @R0,B (错)
(2)MOV A,30H (对)
(3)MOVX A,30H (错)
(4)ADDC A,R7 (对)
(5)SUB A,R2 (错)
(6)ANL #99H ,36H (错)
(7)MOV C,ACC.0 (对)
(8)ORL P1.0,P3.1 (错)
(9)JBC P0,LL1 (错)
(10)ACALL PROC (对)
2、ACALL调用范围和AJMP的转移范围是一样的。(对)
3、直接寻址方式是访问专用寄存器的唯一方法。(错):还可用寄存器寻址方式 二、填空题
1、以助记符形式表示的计算机指令就是它的 汇编 语言。 2、按长度分,MCS-51指令有 1 字节的、 2 字节的和 3 字节的。 3、在寄存器寻址方式中,指令中指定寄存器的内容是 操作数 。 4、在变址寻址方式中,以 A累加器 作变址寄存器,以 DPTR 或 PC 做基址寄存器。 5、假定外部数据存储器2000H单元的内容为80H,执行下列指令后,累加器A中的内容为
80H 。
MOV P2, #20H
MOV R0, #00H
MOVX A, @R0
6、假定累加器A的内容为30H,执行指令:
1000H:MOVC A, @A+PC 后,
把程序存储器 1031H 单元的内容送累加器A中。
7、假定(SP)=60H,(ACC)=30H,(B)=70H,执行下列指令:
PUSH ACC
PUSH B 后,
SP的内容为 62H ,61H单元的内容为 30H ,62H单元的内容为 70H 。 8、假定(A)=85H,(R0)=20H,(20H)=5FH,(CY)=1,执行指令:
ADD A, @R0 后,
累加器A的内容为 E4H ,CY的内容为 0 ,OV的内容为 1 。 9、假定(SP)=40H,(39H)=30H,(40H)=60H。执行下列指令:
POP DPH
POP DPL 后,DPTR的内容为 6030H ,SP的内容是 38H 。
10、假定DPTR的内容为8100H,累加器A的内容为40H,执行下列指令:
MOVC A, @A+DPTR后,
送入A的是程序存储器 8140H 单元的内容。
第五章
一、填空题
1、MCS-51单片机扩展程序存储器所用的控制信号为,扩展数据存储器所用的控制信号为WR和psen
RD。
2、为扩展存储器而构造系统总线,应以P0口的8位口线作为 低8位地址和数据 线,以P2口的
口线作为 高8位地址 线。
3、访问内部RAM使用 MOV 指令,访问外部RAM使用 MOVX 指令,访问内部ROM
使用 MOVC 指令,访问外部ROM使用 MOVC 指令。
4、在存储器扩展中,用线选法还是译码法,最终都是为扩展芯片的 片选 端提供信号。 5、当使用8031单片机时,需要扩展外部程序存储器,此时EA应接__地____。 6、单片机系统中经常采用的地址译码技术包括 译码 和 线选法 方法。二、选择题 1、在MCS-51中,需要双向传递信号的是(B )
A、地址线 B、数据线 C、控制信号线 D、电源线 2、在MCS-51中,为实现P0口线的数据和低位地址复用,应使用(A )
A、地址锁存器 B、地址寄存器 C、地址缓冲器 D、地址译码器 3、在下列信号中,不是给程序存储器扩展使用的是(D )
A、PSEN B、EA C、ALE D、WR
4、如在系统中只扩展一片Intel2732(4K×8),除应使用P口的8根口线外,至少应使用P的( A )02
口线。
(A) 4条 (B) 5条 (C) 6条 (D) 7条
1、 定时器与计数器的工作原理均是对脉冲进行计数。(对)
2、 P3口每个引脚都有两种功能。(对)
3、同级中断中,中断优先级由高到低为外中断0,定时中断0,外中断1,定时中断1,串行中断。(对)
二、填空题MCS-51单片机扩展的I/O端口的编址采用_和存储器统一___编址方式。 2. 定时器/计数器的工作方式2是指将 定时器/计数器 拆成两个独立的8位计数器。而另一个定
时器/计数器此时只可作为 寄存器(TH) 使用。
3、 MCS—51单片机不扩展存储器和I/O接口时,P0通常用作_通用I/O口使用_____,扩展存储器或I/O 接口时,P0通常用作__数据口和低8位地址口___。
4、在接口电路中,把已经编址并能进行读写操作的寄存器称之为 端口 。 5、在MCS-51单片机系统中,扩展的接口采用的编址方式是 和存储器统一编址 。 6、在单片机中,为实现数据的I/O传送,可是用3种传送方式,即: 无条件传送 、
查询式 和 中断式 。
7、在查询和中断两种数据输入输出控制方式中,效率较高的是 中断方式 。 8、在多位LED显示器接口电路的控制信号中,必不可少的是 段 控信号和
位 控信号。
三、选择
1、执行中断返回指令,要从堆栈弹出断点地址,以便去执行被中断了的主程序。从堆栈弹出的断点地址送给(C )
A、A 累加器 B、CY C、PC D、DPTR
3、三态缓冲器的输出应具有三种状态,其中不包括( B )
A、高阻抗状态 B、低阻抗状态 C、高电平状态 D、低电平状态 4、为给扫描法工作的键盘提供接口电路,在接口电路中只需要( B)
A、一个输入口 B、一个输入口和一个输出口 C、一个输出口 D、两个输入口和一个
输出口
5、下列理由中,不能说明MCS-51的I/O编址是统一方式而非独立方式的理由是(D) A、没有专用的I/O指令 B、没有区分存储器和I/O的控制信号
C、使用存储器指令进行I/O操作 D、P3口线具有第二功能 简答题
1. 简述堆栈概念及其存取原则。P53
2. 简述MCS-51单片机中断响应过程。P211
3. 哪些指令能使有效? PSEN
: 能使PSEN有效的指令是:MOVC A,@A+DPTR; MOVC A,@A+PC 4. 访问外部数据存储器的指令是什么?各使用什么控制信号?
RD:读(取)外部数据存储器使用的指令是 MOVX A,@DPTR;控制信号是; 写(送入)外部数据存储器使用的指令是 MOVX @DPTR,A;控制信号是WR。 5、51单片机5个中断源各是什么,各中断源对应的中断服务程序的入口地址是否能任意设定,想将中断服务程序放置在程序存储区的任意区域,在程序中应该作何种设置,请举例加以说明。
:不能。用户可在中断入口地址处存放一条三字节的长转移指令,CPU执行这条长转移指令便可转入相应的中断服务程序执行。
例如:如果INT0中断服务程序起始地址为2000H单元,则如下指令执行后便可转入2000H处执行中断服务程序。
ORG 0003H
LJMP 2000H
6. 说明下列各条指令中源操作数的寻址方式
(1) ANL A,20H 直接寻址
(2) ADDC A, #20H 立即寻址
(3) MOV A,@R1 寄存器间址
(4) MOV 30H, C 位寻址
(5) MOVC A,@A+DPTR 变址寻址
按要求写指令:
1( 片外ROM 2000H单元内容传送到片内RAM60H单元.
CLR A
MOV DPTR,#2000H
MOVC A,@A+DPTR
MOV 60H,A
2( 将30H单元内容减去40H单元内容,差值放入50H单元
CLR C
MOV A,30H
SUBB A,40H
MOV 50H,A
3( 片内RAM 20H单元内容传送到片外RAM20H单元.
MOV R0,#20H
MOV A,20H
MOVX @R0,A
4( 片外RAM 1000H单元内容与片内RAM20H单元内容相加,和放到片外RAM1000H单元. MOV DPTR,#1000H
MOVX A,@DPTR
ADD A,20H
MOVX @DPTR,A
5( 片内RAM 20H单元内容除以30H单元的内容,商送到20H单元,余数送到30H单元.
MOV A,20H
MOV B,30H
DIV AB
MOV 20H,A
MOV 30H,B
6( 片外RAM 20H单元内容传送到片内RAM30H单元. MOV R0,20H
MOVX A,@R0
MOV 30H,A
7( 片外RAM 1000H单元内容传送到片内RAM20H单元. MOV DPTR,#2000H
MOVX A,@DPTR
MOV 20H,A
8( 片外ROM 1000H单元内容传送到片外RAM2000H单元. MOV DPTR,#1000H
CLR A
MOVC A,@A+DPTR
MOV DPTR,#2000H
MOVX @DPTR,A
9( 一条指令就能使A累加器内容变为零的指令写四个. CLR A ANL A,#00H MOV A,#00H
程序设计:
1(有晶振频率为6MHZ的MCS-51单片机,使用定时器1以定时方式1在P1.0输出频率为5KHz的等
宽矩形波,用中断方式产生.
分析:频率为5KHz的方波,即周期为0.2ms, 则每0.1ms产生一次中断,6MHZ,则机器周期为2μS,
方式2,则 100H-32H=0CEH
ORG 0000H
LJMP MAIN
ORG 001BH
LJMP T1
MAIN:MOV TMOD,#20H
MOV IE,#88H
MOV TH1,#0CEH
MOV TL1,#0CEH
SETB P1(0
SETB TR1
HERE: AJMP HERE
T1: CPL P1(0
RETI
END
2.将片外RAM 3000H,303FH单元内容传送到片外RAM 4000H,403FH单元中去.
一种方法:MOV DPTR,#3000H
MOV R2,#64
MOV R0,#00H
LOOP:MOVX A,@DPTR
MOV @R0,A
INC DPTR
INC R0
DJNZ R2,LOOP
MOV DPTR,#4000H
MOV R1,#00H
MOV R3,#64
LOOP1:MOV A,@R0
MOVX @DPTR,A
INC DPTR
INC R1
DJNZ R3,LOOP1
SJMP $
END
第二种方法:MOV DPL #00H
MOV R6,#30H
MOV R7,#40H
MOV R5,#64
LOOP: MOV DPH,R6
MOVX A,@DPTR
MOV DPH,R7
MOVX @DPTR,A
INC DPL
DJNZ R5,LOOP
SJMP $ 硬件电路: 1(设计一个80C51应用系统,扩展一片62128,写出62128的地址范围
答:62128的地址范围是4000H,7FFFH;
A0,A7 P0 74LS373
8051 62128
D0,D7
ALE ALE
RST
P2.0,P2.5 A8,A13
CS P2.6
WRWR
RDRD
范文四:单片机基础+第三版+课后习题答案
第一章,0一、空题填
, 111100EH1001110001100100 , 24
3. 255 -51
题入题题4.
5. 84
6. 630 * 8 * 1024
位 字题 字 7. bit btype word
8. 1111 1111 00100100 11011011
9. 110 89 -115 -50
二、题题,
DBCAB BBCB
第二章,一、空填
, 1PCPC
, 反向器 晶振 只题容 短两2
, 加题 手题 第 30000H07H000H07H , 462112
, 5DPTRDPHDPL
, 664KB
题题题
DCCACAD
第三章,
一、空题,填
, 11031
, 234H111 , 略3
, 41100H
, 52
, 630H71H
0A5H
0A5H
75H
0A7H
0AAH 0 1
IFH 1 1
0AAH 0 1 20H 1 0
0D5H 1 1
49H 0 0
二、题题题
CCBDCA
三、其题型题它
题 题 题
题 题 题 题 题 题 题 题 题
题 题 题
题 题 题
题 题 题
题 题
;三,其题型题它
,题程序写将,题元的高位写~低位写。3RAM20H23H4140
分析,就是把题四题元入个写。用一个的循题。F0HDJNZ ORG 0000H
指向题元MOV R0,#1FH ;R020H
四个数MOV R5,#04H;
LOOP: INC R0
入写MOV @R0,#0F0H ;
循题次DJNZ R5,LOOP ;4
END
,把和题元存有两个数将它并~题合到题元中~题程序完成。写4mm+1BCDm
题高位在~低在数(m=30H, 30H31H) ORG 0000H
MOV A,30H
~把的高四位零它清ANL A,#0FH
SWAP A
~高低四位题一下~放回原题MOV 30H ,A
MOV A,31H
ANL A,#0FH
~合起并来ORL A,30H
MOV 30H,A
END
将内部中从题元题始的个号数无符相加~其和送题元多~假定相加题果小于。题程序完成。写5.RAMdata10sum255
题(data=30H, sun =50H)
ORG 0000H
指向前一题元个MOV R0,#2FH ;
~循题次MOV R5,#0AH10
~先加到中CLR AA
LOOP: INC R0
ADD A,@R0
DJNZ R5,LOOP
MOV 50H,A
END
,假定位二题制题符于号数丰中~要求题一求题程序~所得题题入入写个中。68R0R1
ORG 0000H
MOV A,R0
~按位取反CPL A
~,ADD A,#01H1
MOV R1,A
END
第四章,
一、空题填
1.25H40H03H
,22.914ms
略3.
,;, 4A=((30H) (A) >(30H) (A) <>
5. 32.87ms
题程题
,把题度题的字符串部从内的题入题冲区向位物外部的题出题冲区题送~一直题行到遇题回题或整字符串题送完题。题题程题题。个110HRAMinbufRAMoutbuf
ORG 0030H
MOV R0,#inbuf
MOV R1,#outbuf
MOV R4,#10H
LOOP:MOV A,@R0 ; 部从内RAM取数
CJNE A,#0DH,LL ;是否题回题符CR
SJMP STOP ;是题停止题送0
LL: MOVX @R1,A ;不是题题送到外部RAM
INC R0
INC R1
DJNZ R4,LL;沒题送完题循题
STOP: SJMP $
2、部内RAM从list题元题始存放一正表~表中之作无序排列~以“数数并-1”作题束题志。题程题题在表中出最小。找数
(3AH存放在行程序题的最小的运数)
ORG 0030H
MOV R0,#list
MOV A,@R0 ;取第一正个数
LOOP: INC R0 ;指向下一正个数
MOV 3AH,@R0
CJNE A,3AH,CHK ;前一后一比题个数与个数
CHK: JC LOOP1 ;前一小个数,题题
MOV A,@R0 ;前一大个数,取后一个数
LOOP1: XCH A,3AH
CJNE A,#0FFH,LOOP
XCH A,3AH ;取最小数
MOV 3BH,A
SJMP $
3.部内RAM的X~Y 题元中各存放一题符的~题题程题题按如下件题行的算~题果存入个号数条运并将Z题元中。
若X题正奇~数Z ,X,Y~
若X题正偶~数Z ,X?Y~
若X题题奇~数Z ,X?Y~
若X题题偶~数Z ,XY?。
分析,题,第数7位题1~正,第数7位题0 奇,第数0位题1~偶,第数0位题0
ORG 0000H
MOV A,20H
CLR C
RL A
JC FS ;移到题题题理数
RR A
RR A ;第0位移到C 再判定一下是不是1
JC ZJS ;到正奇题数
MOV A,20H
ORL A,21H
MOV 22H,A
SJMP OK
ZJS: MOV A,20H
ADD A,21H
MOV 22H,A
SJMP OK
FS: MOV A,20H
CLR C
RR A
JC FJS ;第0位是1~移到正 奇题理数
MOV A,20H
XRL A,21H
MOV 22H,A
SJMP OK
FJS: MOV A,20H
ANL A,21H
MOV 22H,A
OK: END
4、把一个8位二题制的各位用数ASCII题表示之;亦题“即0”的位用30H表示~题“1”的位用31H表示,。题存放在部数内RAM中byte题元中。
题题后得到的8个ASCII题存放在外部RAM以buf始的存题题元中去。
ORG 0030H
MOV R0,#byte
MOV DPTR,#buf
MOV R5,#08H
MOV A,@R0
LOOP: RLC A
MOV R7,A
JC LOOP1
MOV A,#30H
SJMP LOOP2
LOOP1: MOV A,#31H
LOOP2: MOVX @DPTR,A
MOV A,R7
INC DPTR
DJNZ R5,LOOP
225.题程题题算式运c = a+b 假定a、 b、 c 3分题存放在部个数内RAM的DA、DB、DC题元中~题有平方算子程序题用。运
;内部RAM的DA、DB、DC题元题题20H 21H 22H,
ORG 0000H
MOV A,20H
PUSH ACC
AJMP SQR
POP ACC
MOV 22H,A
MOV A,21H
PUSH ACC
AJMP SQR
POP ACC
ADD A,22H
MOV 22H,A
END
6、比题两个ASCII题字符串是否相等。字符串的题度在部内RAM 41H题元~第一字符串的首地址题个42H~第二字符串的首地址题个52H。如果两个
字符串相等~题置部内RAM 40H题元题00H~否题置40H题元题FF。
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
SETB E7H; E7H就是累加器A的最高位(ACC.7), 也可 : SETB ACC.7
MOVX @DPTR,A
INC DPTR
DJNZ R6,LOOP ,题程序写将,题元的高位写~低位写。3RAM20H23H4140
分析,就是把题四题元入个写。用一个的循题。F0HDJNZ
ORG 0000H
指向题元MOV R0,#1FH ;R020H
四个数MOV R5,#04H;
LOOP: INC R0
入写MOV @R0,#0F0H ;
循题次DJNZ R5,LOOP ;4
END
,把和题元存有两个数将它并~题合到题元中~题程序完成。写4mm+1BCDm
题高位在~低在数(m=30H, 30H31H)
ORG 0000H
MOV A,30H
~把的高四位零它清ANL A,#0FH
SWAP A
~高低四位题一下~放回原题MOV 30H ,A
MOV A,31H
ANL A,#0FH
~合起并来ORL A,30H
MOV 30H,A
END
将内部中从题元题始的个号数无符相加~其和送题元多~假定相加题果小于。题程序完成。写5.RAMdata10sum255
题(data=30H, sun =50H)
ORG 0000H
指向前一题元个MOV R0,#2FH ;
~循题次MOV R5,#0AH10
~先加到中CLR AA
LOOP: INC R0
ADD A,@R0
DJNZ R5,LOOP
MOV 50H,A
END
,假定位二题制题符于号数丰中~要求题一求题程序~所得题题入入写个中。68R0R1
ORG 0000H
MOV A,R0
~按位取反CPL A
~,ADD A,#01H1
MOV R1,A
END
第四章,
一、空题填
1.25H40H03H
,22.914ms
略3.
,;, 4A=((30H) (A) >(30H) (A) <>
5. 32.87ms
题程题
,把题度题的字符串部从内的题入题冲区向位物外部的题出题冲区题送~一直题行到遇题回题或整字符串题送完题。题题程题题。个110HRAMinbufRAMoutbuf
ORG 0030H
MOV R0,#inbuf
MOV R1,#outbuf
MOV R4,#10H
LOOP:MOV A,@R0 ; 部从内RAM取数
CJNE A,#0DH,LL ;是否题回题符CR
SJMP STOP ;是题停止题送
LL: MOVX @R1,A ;不是题题送到外部RAM
INC R0
INC R1
DJNZ R4,LL;沒题送完题循题
STOP: SJMP $
2、部内RAM从list题元题始存放一正表~表中之作无序排列~以“数数并-1”作题束题志。题程题题在表中出最小。找数
(3AH存放在行程序题的最小的运数)
ORG 0030H
MOV R0,#list
MOV A,@R0 ;取第一正个数
LOOP: INC R0 ;指向下一正个数
MOV 3AH,@R0
CJNE A,3AH,CHK ;前一后一比题个数与个数
CHK: JC LOOP1 ;前一小个数,题题
MOV A,@R0 ;前一大个数,取后一个数
LOOP1: XCH A,3AH
CJNE A,#0FFH,LOOP
XCH A,3AH ;取最小数
MOV 3BH,A
SJMP $
3.部内RAM的X~Y 题元中各存放一题符的~题题程题题按如下件题行的算~题果存入个号数条运并将Z题元中。
若X题正奇~数Z ,X,Y~
若X题正偶~数Z ,X?Y~
若X题题奇~数Z ,X?Y~
若X题题偶~数Z ,XY?。
分析,题,第数7位题1~正,第数7位题0 奇,第数0位题1~偶,第数0位题0
ORG 0000H
MOV A,20H
CLR C
RL A
JC FS ;移到题题题理数
RR A
RR A ;第0位移到C 再判定一下是不是1
JC ZJS ;到正奇题数
MOV A,20H
ORL A,21H
MOV 22H,A
SJMP OK
ZJS: MOV A,20H
ADD A,21H
MOV 22H,A
SJMP OK
FS: MOV A,20H
CLR C
RR A
JC FJS ;第0位是1~移到正 奇题理数
MOV A,20H
XRL A,21H
MOV 22H,A
SJMP OK
FJS: MOV A,20H
ANL A,21H
MOV 22H,A
OK: END
4、把一个8位二题制的各位用数ASCII题表示之;亦题“即0”的位用30H表示~题“1”的位用31H表示,。题存放在部数内RAM中byte题元中。
题题后得到的8个ASCII题存放在外部RAM以buf始的存题题元中去。
ORG 0030H
MOV R0,#byte
MOV DPTR,#buf
MOV R5,#08H
MOV A,@R0 LOOP: RLC A
MOV R7,A
JC LOOP1
MOV A,#30H
SJMP LOOP2
LOOP1: MOV A,#31H
LOOP2: MOVX @DPTR,A
MOV A,R7
INC DPTR
DJNZ R5,LOOP
225.题程题题算式运c = a+b 假定a、 b、 c 3分题存放在部个数内RAM的DA、DB、DC题元中~题有平方算子程序题用。运
;内部RAM的DA、DB、DC题元题题20H 21H 22H,
ORG 0000H
MOV A,20H
PUSH ACC
AJMP SQR
POP ACC
MOV 22H,A
MOV A,21H
PUSH ACC
AJMP SQR
POP ACC
ADD A,22H
MOV 22H,A
END
6、比题两个ASCII题字符串是否相等。字符串的题度在部内RAM 41H题元~第一字符串的首地址题个42H~第二字符串的首地址题个52H。如果两个
字符串相等~题置部内RAM 40H题元题00H~否题置40H题元题FF。
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
SETB E7H; E7H就是累加器A的最高位(ACC.7), 也可 : SETB ACC.7
MOVX @DPTR,A
INC DPTR
DJNZ R6,LOOP
第五章
一、空题填
,各题任题1
, 串口2INT0T0INT1T1
, 3PCPCROM
,中源 题题题断状4
, 510000001000000/65536 = 15.26
,6100 ms
,7111 101
,8T1 2 0FFH 001BH
二、题题题,
DCAADCD
题片机基题 第五章 题题
题本。题题片机的晶振题率题~使用定题器以方式题生的等题正方波题题~由脉冲并题出。5.16MHZ10500usP1.0
分析,使用题出~可由定题器题生一脉冲个的定题~到了题题~就题行 就可以了。所以题题题化题题生定题。P1.0250usCPLP1.0解,;, 题算定题器的初题,1
13 ;,,, , 2XTT机定题
代入据得,数 , X8067
由于方式的特点;高位~低位,~题算出~085TH1TL1
得 , , TH10FCHTL103H
;,题算出的初始题,2TMOD
,TMOD00H
;,题程题题,3
方法一,使用题题法。程序不地题题断的题。如定题器溢出;,,~题 TF1TF11CPLP1.0
所以, MOV TMOD ,#00H
MOV TH1,#0FCH
MOV TL1,#03H
不用中的方法~题掉断MOV IE, #00H ;
题定题器启SETB TR1 ;
LOOP: JBC TF1,LOOP1
AJMP LOOP
LOOP1: MOV TH1,#0FCH
MOV TL1,#03H
CPL P1.0
AJMP LOOP
方法二,使用中的方法。需定寄存器,断确 , TMOD00H
,或 IE88H TCON =40H (SETBTR1) 的中向量,断T1001BH
程序如下,
ORG 0000H
AJMP MAIN
ORG001BH
,AJMPT1TIMER
, ~,MAINMOVTMOD00H
~,MOVTCON40H
MOVIE,#88H
MOV TCON ,#40H
MOV TH1,#0FCH
MOV TL1,#03H
Here :AJMP HereT1_TIMER: MOV TH1,#0FCH
MOV TL1,#03H
CPL P1.0
RETI
注意,定题器定题或题~不影数会响的工作。CPU
定题方式,方式与没区有大的题~只有定题器是位的。所以1016
x定题,;初题, 2 –T机
方式,位初题自题题题的定题题器数28/
解法一题,
;,题算的初始题 ;, ,,1T2TMOD
;,程序题题 2
方式三,
,T0
―― 位~可作定题也可作题~方式数与一题使用。TL080,
――,位~只能作定题~借作 TH08TR1TF1 ,没断断脉冲法中~只能题生不的~,,全波特率T1
可用方式~。如要停止~要强制题方式脉冲0,123
第六章一、空题填
、 1816132
、 高题平 低题平 高阻2
、 据 数 程序 据 数 程序32564KB64KB64KB
、 416P0P2
、 5PSENRDWRALECEALE6
、 616KB31FFH
、 外存 7
、 片题8
、 93PSENALE
二、题题题
DADDCADA
第七章
填空题
, 据 数 1ALERDWR , 无件题送 题题 中条断2
, 题 题存冲3
, 41211
, 高 口方式定题 位置位题位5C/ , 方式题出 方式题出 题出 题入611 , 710100111题题题
DACDBB
范文五:单片机基础第三版答案_李广弟
************************
第一章:
一、填空题
1.11100EH 1001110001100100
2.4
3. 255-51
4. 输入设备
5. 84
6. 630*8*1024
7. 位字节字bit btype word
8. 111111110010010011011011
9. 11089-115-50
二、单选:
DBCAB BBCB
第二章:
一、填空
1.PC PC
2.反向器晶振两只电容短
3.加电手动0000H 07H
4.62112
5.DPTR DPH DPL
6.64KB
单选题
DCCAC A D
一、填空题:
1.1031
2.34H 111
3.略
4.1100H
5.2
6.30H 71H
0A5H
0A5H
75H
0A7H
0AAH 01
IFH 11
0AAH 01第000H 07H 第三章:
20H 10
0D5H 11
49H 00
二、单选题
CCBDCA
三、其它类型题
错错
错错
对错
错错
对对
错对
错对
错对对错错对对对错
(三)其它类型题
3.编写程序将RAM20H -23H 单元的高4位写1,低4位写0。
分析:就是把这四个单元写入F0H 。用一个DJNZ 的循环。
ORG 0000H
MOV R0,#1FH;R0指向20H 单元
MOV R5,#04H;四个数
LOOP:INC R0
MOV @R0,#0F0H; 写入
DJNZ R5,LOOP ; 循环4次
END
4.把m 和m+1单元存有两个BCD 数,将它们合并到m 单元中,编写程序完成。
(设m=30H,高位在30H ,低数在31H)
ORG 0000H
MOV A,30H
ANLA,#0FH;把它的高四位清零
SWAP A
MOV 30H ,A ;高低四位调一下,放回原处
MOV A,31H
ANLA,#0FH
ORLA,30H ;合并起来
MOV 30H,A
END
5. 将内部RAM 中从data 单元开始的10个无符号数相加,其和送sum 单元多,假定相加结果小于255。编写程序完成。
(设data=30H,sun =50H)
ORG 0000H
MOV R0,#2FH; 指向前一个单元
MOV R5,#0AH;循环10次
CLR A ;先加到A 中
LOOP:INC R0
ADDA,@R0
DJNZ R5,LOOP
MOV 50H,A
END
6.假定8位二进制带符号数丰于R0中,要求编写一个求补程序,所得补码入入R1中。
ORG 0000H
MOV A,R0
CPL A ;按位取反
ADDA,#01H;+1
MOV R1,A
END 第四章:
一、填空题
1. 25H 40H 03H
2.2.914ms
3. 略
4.(A )=((30H)(A)>(30H)(A)<>
5. 32.87ms
编程题
1.把长度为10H 的字符串从内部RAM 的输入缓冲区inbuf 向位物外部RAM 的输出缓冲区outbuf 传送,一直进行到遇见回车或整个字符串传送完毕。试编程实现。
ORG 0030H
MOV R0,#inbuf
MOV R1,#outbuf
MOV R4,#10H
LOOP:MOVA,@R0; 从内部RAM 取数
CJNE A,#0DH,LL;是否为回车符CR
SJMP STOP ;是转停止传送
LL:MOVX @R1,A;不是则传送到外部RAM
INC R0
INC R1
DJNZ R4,LL;沒传送完则循环
STOP:SJMP $
2、内部RAM 从list 单元开始存放一正数表,表中之数作无序排列,并以“-1”作结束标志。编程实现在表中找出最小数。
(3AH存放在运行程序时的最小的数)
ORG 0030H
MOV R0,#list
MOV A,@R0;取第一个正数
LOOP:INC R0;指向下一个正数
MOV 3AH,@R0
CJNE A,3AH,CHK ;前一个数与后一个数比较
CHK:JC LOOP1;前一个数小,则转
MOV A,@R0;前一个数大,取后一个数
LOOP1:XCH A,3AH
CJNE A,#0FFH,LOOP
XCH A,3AH ;取最小数
MOV 3BH,A
SJMP $
3.内部RAM 的X,Y单元中各存放一个带符号的数,试编程实现按如下条件进行的运算,并将结果存入Z 单元中。
若X 为正奇数,Z=X+Y;
若X 为正偶数,Z=X∨Y;
若X 为负奇数,Z=X∧Y;
若X 为负偶数,Z=X⊕Y。
分析:负数:第7位为1,正数:第7位为0
奇数:第0位为1,偶数:第0位为0
ORG 0000H
MOV A,20H
CLR C
RL A
JC FS ;移到负数处处理
RR A
RR A ;第0位移到C 再判定一下是不是1
JC ZJS ;到正奇数处
MOV A,20H
ORL A,21H
MOV 22H,A
SJMP OK
ZJS:MOV A,20H
ADD A,21H
MOV 22H,A
SJMP OK
FS:MOV A,20H
CLR C
RR A
JC FJS ;第0位是1,移到正奇数处理
MOV A,20H
XRL A,21H
MOV 22H,A
SJMP OK
FJS:MOV A,20H
ANL A,21H
MOV 22H,A
OK:END
4、把一个8位二进制数的各位用ASCII 码表示之(亦即为“0”的位用30H 表示,为“1”的位用31H 表示)。该数存放在内部RAM 中byte 单元中。变换后得到的8个ASCII 码存放在外部RAM 以buf 始的存储单元中去。
ORG 0030H
MOV R0,#byte
MOV DPTR,#buf
MOV R5,#08H
MOV A,@R0
LOOP:RLC A
MOV R7,A
JC LOOP1
MOV A,#30H
SJMP LOOP2
LOOP1:MOV A,#31H
LOOP2:MOVX @DPTR,A
MOV A,R7
INC DPTR
DJNZ R5,LOOP
5.编程实现运算式c =a 2+b2假定a、b、c 3个数分别存放在内部RAM 的DA、DB、DC单元中,别有平方运算子程序调用。
(内部RAM 的DA、DB、DC单元设为20H 21H 22H )
ORG 0000H
MOV A,20H
PUSH ACC
AJMP SQR
POP ACC
MOV 22H,A
MOV A,21H
PUSH ACC
AJMP SQR
POP ACC
ADD A,22H
MOV 22H,A
END
6、比较两个ASCII 码字符串是否相等。字符串的长度在内部RAM 41H 单元,第一个字符串的首地址为42H,第二个字符串的首地址为52H。如果两个字符串相等,则置内部RAM 40H 单元为00H;否则置40H 单元为FF。
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:MOVXA,@DPTR
SETB E7H ; E7H 就是累加器A 的最高位(ACC.7),也可:SETB ACC.7
MOVX @DPTR,A
INC DPTR
DJNZ R6,LOOP
第五章
一、填空题
1.
2.
3.
4.
5.
6.
7.
8.各项任务INT0T0INT1T1串口PC PC ROM 中断源查询状态10000001000000/65536=15.26100ms 111101T120FFH 001BH
二、单选题:
DCAADCD
单片机基础第五章习题
课本5。.1设单片机的晶振频率为6MHZ ,使用定时器1以方式0产生500us 的等宽正方波连续脉冲,并由P1.0输出。
分析:使用P1.0输出脉冲,可由定时器产生一个250us 的定时,到了时间,就执行CPL P1.0就可以了。所以问题转化为产生定时。解:(1)计算定时器的初值:
(213-X )*T 机=T 定时
代入数据得:X =8067
由于方式0的特点(高8位,低5位),计算出TH1,TL1
得TH1=0FCH TL1=03H
(2)计算出TMOD 的初始值:
TMOD =00H
(3)编程实现:
方法一:使用查询法。程序不断地查询TF1的值。如定时器溢出(TF1=1),则所以:MOV TMOD ,#00H
MOV TH1,#0FCH
MOV TL1,#03H
MOV IE, #00H; 不用中断的方法,关掉
SETB TR1; 开启定时器
LOOP:JBC TF1,LOOP1
AJMP
LOOP1:MOV TH1,#0FCH
MOV TL1,#03H
CPL P1.0CPL P1.0
AJMP LOOP
方法二:使用中断的方法。需确定寄存器:TMOD
IE =88H TCON =40HSETB TR1)
T1的中断向量=001BH
程序如下:
ORG 0000H
AJMP MAIN
ORG 001BH
AJMP T1_TIMER
MAIN :MOV TMOD ,#00H
MOV TCON ,#40H
MOV IE,#88H
MOV TCON ,#40H=00H
MOV TH1,#0FCH
MOV TL1,#03H
Here :AJMPHere
T1_TIMER:MOV TH1,#0FCH
MOV TL1,#03HCPL P1.0
RETI
注意:定时器定时或计数,不会影响CPU 的工作。
定时方式1:与方式0没有大的区别,只有定时器是16位的。所以定时=(2x –初值)T 机
方式2:8位初值自动赋值的定时/计数器
解法一样:
(1)计算T 的初始值(2)TMOD =?
(2)程序设计
方式三:
T0:
――TL08位,可作定时也可作计数,与方式0, 一样使用。――TH0:8位,只能作定时,借作TR1TF1
T1:没法中断,只能产生不断的脉冲,--全波特率
可用方式0,1,2。如要停止脉冲,要强制设方式3
一、填空题
1、816132
2、高电平低电平高阻
3、256数据4KB 程序
4、16P0P2
5、PSEN RD WR ALE
6、16KB 31FFH
7、外存
8、片选
9、3PSEN ALE 64KB CE 数据ALE 664KB 程序
二、单选题
DADDC ADA
填空题
1.数据ALE RD WR
2.无条件传送查询中断
3.缓冲锁存
4.1211
5.高口方式定义C 位置位/复位
6.方式1输出方式1输出输出
7.10100111
单选题
DACDBB 第七章输入