单片机原理及接口技术课后答案_第1页
单片机原理及接口技术课后答案_第2页
单片机原理及接口技术课后答案_第3页
单片机原理及接口技术课后答案_第4页
免费预览已结束,剩余49页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、单片机原理及接口技术课后答案_(第三版)第一章1. 单片机具有哪些特点( 1)片内存储容量越来越大。( 2 抗干扰性好,可靠性高。( 3)芯片引线齐全,容易扩展。( 4)运行速度高,控制功能强。( 5)单片机内部的数据信息保存时间很长,有的芯片可以达到100 年以上。2. 89C51 单片机内包含哪些主要逻辑功能部件?答: 80C51系列单片机在片内集成了以下主要逻辑功能部件:(l)CPU(中央处理器 ):8位(2) 片内 RAM:128B(3) 特殊功能寄存器 :21 个(4) 程序存储器 :4KB(5) 并行 I/O 口:8 位, 4 个(6) 串行接口 : 全双工, 1 个(7) 定时器

2、 / 计数器 :16 位, 2 个(8) 片内时钟电路 :1 个3. 什么是微处理器 (CPU)、微机和单片机?答:微处理器本身不是计算机,但它是小型计算机或微机的控制和处理部分。微机则是具有完整运算及控制功能的计算机,除了微处理器外还包括存储器、接口适配器以及输入输出设备等。单片机是将微处理器、一定容量的 RAM、ROM以及 I/O 口、定时器等电路集成在一块芯片上,构成的单片微型计算机。4. 微型计算机怎样执行一个程序?答:通过 CPU指令,提到内存当中,再逐一执行。5. 什么是嵌入式系统?他有哪些类型?为什么说单片机是典型的嵌入式系统?答 ; 嵌入式系统是将先进的计算机技术、半导体技术和

3、电子技术和各个行业的具体应用相结合后的产物,这一点就决定了它必然是一个技术密集、资金密集、高度分散、不断创新的知识集成系统。它有嵌入式微处理器、 嵌入式微控制器、 嵌入式 DSP处理器、嵌入式片上系统等。嵌入式系统的出现最初是基于单片机的。 它从体系结构到指令系统都是按照嵌入式应用特点专门设计的,能最好的满足面对控制对象,应运系统的嵌入、现场的可靠运行以及非凡的控制品质要求。因此,她是典型的嵌入式系统。第二章1.89C51 单片机内包含哪些主要逻辑功能部件?答: 80C51系列单片机在片内集成了以下主要逻辑功能部件:(l)CPU(中央处理器 ):8位(2) 片内 RAM:128B(3) 特殊功

4、能寄存器 :21 个(4) 程序存储器 :4KB(5) 并行 I/O 口:8 位, 4 个(6) 串行接口 : 全双工, 1 个(7) 定时器 / 计数器 :16 位, 2 个(8) 片内时钟电路 :1 个2.89C51 的 EA端有何用途?答: /EA 端接高电平时, CPU只访问片内并执行内部程序,存储器。平时, CPU只访问外部ROM,并执行片外程序存储器中的指令。/EA时, CPU执行内部存储器中的指令。/EA 端接低电端保持高电平3. 89C51 的存储器分哪几个空间 ?如何区别不同空间的寻址 ?答:ROM(片内 ROM和片外 ROM统一编址)(使用 MOVC)(数据传送指令) (

5、16bits 地址)( 64KB)片外 RAM( MOVX)( 16bits地址)( 64KB)片内 RAM( MOV)( 8bits地址)( 256B)4. 简述 89C51 片内 RAM的空间分配。答:片内 RAM有 256B低 128B 是真正的 RAM区高 128B 是 SFR(特殊功能寄存器)区5. 简述布尔处理存储器的空间分配,片内 RAM中包含哪些可位寻址单元。答:片内 RAM区从 00HFFH(256B)其中 20H2FH(字节地址)是位寻址区对应的位地址是 00H7FH6. 如何简捷地判断 89C51正在工作 ?答:用示波器观察 8051 的 XTAL2端是否有脉冲信号输出(

6、判断震荡电路工作是否正常?)ALE (地址锁存允许)( Address Latch Enable )输出是 fosc 的用示波器观察 ALE是否有脉冲输出(判断 8051 芯片的好坏?)6 分频观察 PSEN(判断 8051 能够到 EPROM或 ROM中读取指令码?)因为 /PSEN接外部 EPROM(ROM)的 /OE 端子OE=Output Enable(输出允许)7. 89C51如何确定和改变当前工作寄存器组?答: PSW(程序状态字)(Program Status Word可以给出 4 中组合用来从 4 组工作寄存器组中进行选择PSW属于 SFR( Special Function

7、Register)中的 RS1和 RS0)(特殊功能寄存器)8. 89C51 P0口用作通用 / 口输入时,若通过TTL“OC”门输入数据,应注意什么 ?为什么 ?答:9. 读端口锁存器和“读引脚”有何不同?各使用哪种指令?答:读锁存器(ANL P0,A)就是相当于从存储器中拿数据,而读引脚是从外部拿数据(如 MOVA,P1 这条指令就是读引脚的, 意思就是把端口 p1 输入数据送给 A)传送类 MOV,判位转移 JB、JNB、这些都属于读引脚,平时实验时经常用这些指令于外部通信,判断外部键盘等; 字节交换 XCH、XCHD算术及逻辑运算ORL、CPL、ANL、ADD、ADDC、SUBB、IN

8、C、 DEC控制转移 CJNE、DJNZ都属于读锁存器。10. 89C51 P0 P3 口结构有何不同 ?用作通用 / 口输入数据时,应注意什么?答: P0 口内部没有上拉电阻,可以用做16 位地址的低8 位;P3 有第二功能;P2 口可以用做16 位地址的高8 位;需要上拉电阻。 OC门电路无法输出高低电平,只有靠上拉电阻才能实现11. 89C51 单片机的信号有何功能 ?在使用 8031 时,信号引脚应如何处理 ?答: (1)80C51 单片机的 EA 信号的功能EA 为片外程序存储器访问允许信号,低电平有效 ; 在编程时,其上施加 21V 的编程电压EA 引脚接高电平时, 程序从片内程序

9、存储器开始执行, 即访问片内存储器 ;EA 引脚接低电平时,迫使系统全部执行片外程序存储器程序。(2) 在使用 80C31时,EA 信号引脚的处理方法因为 80C31没有片内的程序存储器,所以在使用它时必定要有外部的程序存储器, EA 信号引脚应接低电平。12. 89C51 单片机有哪些信号需要芯片引脚以第2 功能的方式提供 ?答:第一功能第二功能串行口:RXD(串行输入口)TXD(串行输出口)中断:INT0外部中断 0INT1外部中断 1定时器 / 计数器( T0、 T1):T0(定时器 / 计数器 0 的外部输入)T1(定时器 / 计数器 1 的外部输入)数据存储器选通:WR(外部存储器写

10、选通,低电平有效,输出)RD(外部存储器读选通,低电平有效,输出)定时器 / 计数器( T2):T2(定时器 T2 的计数端)T2EX(定时器 T2 的外部输入端)13. 内部 RAM低 128 字节单元划分为哪 3 个主要部分 ?各部分主要功能是什么 ? 答:片内 RAM低 128 单元的划分及主要功能 :(l) 工作寄存器组 (00HlFH)这是一个用寄存器直接寻址的区域,内部数据RAM区的 031(00HlFH), 共32 个单元。它是 4 个通用工作寄存器组,每个组包含8 个 8 位寄存器,编号为R0R7。(2) 位寻址区 (20H2FH)从内部数据 RAM区的 3247(20H2FH

11、)的 16 个字节单元,共包含128 位,是可位寻址的 RAM区。这 16个字节单元,既可进行字节寻址,又可实现位寻址。(3) 字节寻址区(30H7FH)从内部数据 RAM区的 48127(30H7FH),共 80 个字节单元, 可以采用间接字节寻址的方法访问。14. 使单片机复位有几种方法 ?复位后机器的初始状态如何 ? 答: (1) 单片机复位方法单片机复位方法有 : 上电自动复位、 按键电平复位和外部脉冲三种方式, 如题图 2-1 所示。题图 2-1(2) 复位后的初始状态复位后机器的初始状态 , 即各寄存器的状态 :PC 之外 , 复位操作还对其他一些特殊功能寄存器有影响 , 它们的复

12、位状态如题表 2-1 所例15. 开机复位后, CPU 使用的是哪组工作寄存器 ?它们的地址是什么 ?CPU 如何确定和改变当前工作寄存器组 ?答:一般开机复位后都是选择第一组通用工作寄存器作为工作寄存器的,一共有4 组,分别为 0.1.2.3 连续位于 00h 到 1FH地址,然后在机器中有个程序状态字 PSW,它的第四和第三位 RS1,RS0是用来选择工作寄存器组的,可能不同机器地址稍有不同。他们俩的值和寄存器组的关系:RS1/RS00/00/11/01/1使用的工作寄存器012 3地址00-07 08-0F 10-17 18-1F写程序的时候就是通过定义程序状态字来选择使用不同的寄存器组

13、。也可以直接对 RS1和 RS0赋值。(最后一问同题 7)16. 程序状态寄存器 PSW的作用是什么 ?常用标志有哪些位 ?作用是什么 ? 答: PSW是一个 SFR(特殊功能寄存器)位于片内 RAM的高 128B具体地址 D0H( 00HFFH)(片内 RAM的编址)(PSW=Program Status Word(程序状态字)8bits编址方法)PSW的常用标志位有哪些?CY=Carry(进位标志位)AC=Auxiliary Carry(辅助进位标志位)(半进位标志位)F0用户标志位RS1,RS0,用来选择当前工作寄存器组(OV=Overflow(溢出标志位)R0R7)( 4选1)P=Pa

14、rity(奇偶校验位)17. 位地址 7CH与字节地址 7CH如何区别 ?位地址 7CH具体在片内 RAM中的什么位置 ?答:用不同的寻址方式来加以区分,即访问128 个位地址用位寻址方式,访问低128 字节单元用字节寻址和间接寻址。具体地址为 2F 的第五位,即为 7C。18. 89C51 单片机的时钟周期与振荡周期之间有什么关系 ?什么叫机器周期和指令周期?答:时钟信号的周期称为机器状态周期,是振荡周期的两倍。一个机器周期是指CPU访问存储器一次所需的时间。指令周期是执行一条指令所需的时间。19. 一个机器周期的时序如何划分 ?答:一个机器周期=12 个震荡周期 =6 个时钟周期(状态周期

15、)S1P1 ,S1P2,S2P1,S2P2,S3P1, S3P2, S4P1, S4P2,S5P1,S5P2, S6P1, S6P2 其中 s=state (状态), p=phase(相位)20. 什么叫堆栈 ?堆栈指针 SP的作用是什么 ?89C51单片机堆栈的容量不能超过多少字节 ?答:堆栈都是一种数据项按序排列的数据结构, 只能在一端 ( 称为栈顶 (top) 对数据项进行插入和删除。要点:堆:顺序随意栈:后进先出(Last-In/First-Out)在调用子程序时需要保存调用函数的 CPU寄存器 PC指针 ,PC 指针是被 CALL 指令自动压入 SP所指向的片内存储器 ,CPU寄存器

16、要由用户用 PUSH指令自行保存 , 因此 SP 的作用就是一个指针 , 当进行中断调用 , 子函数调用时将现场数据压入 SP 所指向的存储器 ,SP 自动增加 1 或 2, 当中断结束 RETI, 调用返回 RET,POP时将 SP 数据弹出 ,SP 自动减 1 或, 28051 最大为 128 字节的片内存储器 ,0X20 以上理论都可以做堆栈用96 字节 ,8052为 256 字节 224 字节可用,但这样便没有其它空间可用于数据存储现在的单片机的程序一般都能用 C51来, 不用关心堆栈大小与 SP寄存器21. 89C51 有几种低功耗方式?如何实现?答:空闲方式和掉电方式空闲方式和掉电

17、方式是通过对 SFR中的 PCON(地址 87H)相应位置 1 而启动的。当 CPU执行完置 IDL=1)的指令后,系统进入空闲工作方式。这时,内部时钟不向 CPU提供,而只供给中断、串行口、定时器部分。 CPU的内部状态维持,即包括堆栈指针 SP、程序计数器 PC、程序状态字 PSW、累加器 ACC所有的内容保持不变,端口状态也保持不变。 ALE和 PSEN保持逻辑高电平。当 CPU执行一条置位( PD)为 1 的指令后,系统进入掉电工作方式。在这种工作方式下,内部振荡器停止工作。由于没有振荡时钟,因此,所有的功能部件都停止工作。但内部 RAM区和特殊功能寄存器的内容被保留,而端口的输出状态

18、值都保存在对应的 SFR中, ALE和 PSEN都为低电平。22. PC 与 DPTR各有哪些特点?有何异同?答: (1) 程序计数器 PC作为不可寻址寄存器的特点程序计数器 PC是中央控制器申最基本的寄存器, 是一个独立的计数器, 存放着下一条将程序存储器中取出的指令的地址。程序计数器 PC变化的轨迹决定程序的流程。 程序计数器的宽度决定了程序存储器可以寻址的范围。程序计数器 PC的基本工作方式有 :程序计数器 PC自动加 1。这是最基本的工作方式, 也是这个专用寄存器被称为计数器的原因。执行条件或无条件转移指令时,程序计数器将被置入新的数值,程序的流向发生变化。变化的方式有下列几种 : 带

19、符号的相对跳转 SJMP、短跳转 AJMP、长跳转 LJMP及 JMP A+DPTR等。在执行调用指令或响应中断时:PC的现行值,即下一条将要执行的指令的地址送入堆栈,加以保护;将子程序的入口地址或者中断矢量地址送入 PC,程序流向发生变化,执行子程序或中断服务程序 ;子程序或中断服务程序执行完毕, 遇到返回指令 RET或 RETI 时,将栈顶的内容送到 PC寄存器中,程序流程又返回到原来的地方,继续执行。(2) 地址指针 DPTR的特点地址指针 DPTR的特点是,它作为片外数据存储器寻址用的地址寄存器 ( 间接寻址)。(3) 地址指针 DPTR与程序计数器 PC的异同相同之处 :两者都是与地

20、址有关的、 16 位的寄存器。 其中,PC与程序存储器的地址有关,而DPTR与数据存储器的地址有关。作为地址寄存器使用时, PC与 DPTR都是通过 P0 和 P2 口( 作为 16 位地址总线)输出的。但是, PC 的输出与 ALE 及 PSEN有关 ;DPTR 的输出,则与 ALE、 RD 及 WR相联系。不同之处 :PC只能作为 16 位寄存器对待,由于有自动加1 的功能, 故又称为计数器DPTR可以作为 16 位寄存器对待,也可以作为两个8 位寄存器对待。;PC是不可以访问的, 有自己独特的变化方式, 它的变化轨迹决定了程序执行的流程 ;DPTR是可以访问的,如MOVDPTR,#XXX

21、XH,INC DPTP。23. 89C51 端口锁存器的“读修改写”操作与“读引脚”操作有何区别?答:指令系统中有些指令读锁存器的值, 有些指令则读引脚上的值。读锁存器指令是从锁存器中读取一个值并进行处理 , 把处理后的值 ( 原值或已修改后的值 ) 重新写入锁存器中。这类指令称为读 - 修改 - 写指令。对于读 - 修改 - 写指令。直接读锁存器而不是读端口引脚 , 是因为从引脚上读出的数据不一定能真正反映锁存器的状态。第三章1、 指令: CPU根据人的意图来执行某种操作的命令指令系统:一台计算机所能执行的全部指令集合机器语言:用二进制编码表示,计算机能直接识别和执行的语言汇编语言:用助记符

22、、符号和数字来表示指令的程序语言高级语言:独立于机器的,在编程时不需要对机器结构及其指令系统有深入了解的通用性语言2、见第 1题3、简述 8951 的汇编指令格式。答:操作码 目的操作数 ,源操作数 4、简述 8951 的寻址方式和所能涉及的寻址空间。寻址方式寻址空间立即数寻程序存储器 ROM址直接寻址片内 RAM低 128B、特殊功能寄存器寄存器寻工作寄存器 R0-R7、 A、B、C、 DPTR址寄存器间片内 RAM低 128B、片外 RAM接寻址变址寻址程序存储器( A+PC,A+DPTR)相对寻址程序存储器 256B 范围( PC+偏移量)位寻址片内 RAM的 20H-2FH字节地址、部

23、分 SFR5、访问特殊功能寄存器和外数据存储器,应采用那些寻址方式?答:SFR:直接寻址,位寻址,寄存器寻址;片外RAM:寄存器间接寻址6、8951 中已知( 30H)=38H,请分析以下各是什么指令,说明源操作数的寻址方式以及执行结果。MOV A,40H;直接寻址( 40H) AMOV R0 , A;寄存器寻址( A) R0MOV P1 ,#0F0H ;立即数寻址 0F0P1MOVR0,30H ;直接寻址( 30H) ( R0)MOV DPTR,#3848H ;立即数寻址 3848H DPTRMOV 40H,38H;直接寻址(38H) 40HMOVR0,30H;直接寻址(30H) R0MOV

24、P0,R0 ;寄存器寻址( R0 ) P0MOV18H , #30H ;立即数寻址 30H 18HMOVA,R0;寄存器间接寻址(R0)AMOVP2, P1;直接寻址(P1) P2最后结果:( R0)=38H,(A)=40H,( P0)=38H,(P1)=(P2)=0F0H,(DPTR)=3848H,( 18H) =30H,( 30H) =38H,( 38H) =40H,( 40H)=40H,(48H)=38H注意:左边是内容,右边是单元7、8951 片内高 128 字节的地址寻址要注意什么/?答:用直接寻址,位寻址,寄存器寻址8、指出些列指令的本质?MOVA,DATA; 直接寻址2 字节 1

25、 周期MOVA,#DATA ; 立即数寻址 2 字节 1 周期MOVDATA1,DATA2;直接寻址3 字节 2 周期MOV74H,#78H ; 立即数寻址 3 字节 2 周期如果想查某一指令的机器码,字节数或周期数可查阅书本后面的附录A9、设 R0的内容分为 32H,A 的内容为 48H,。请指出在执行下列程序段后上述各单元内容的变化?MOVA,R0;(R0)=80HAMOVR0,40H ;(40H)=08H (R0)MOV40H,A ;(A)=80 40HMOVR0,#35H ;35H R0最后结果:(R0)=35H (A)=80H,( 32H)=08H,(40H) =80H 10、如何访

26、问 SFR,可采用那些寻址方式?答:用直接寻址,位寻址,寄存器寻址11、如何访问片外RAM,可使用那些寻址方式?答:只能采用寄存器间接寻址(用MOVX指令)12、如何访问片内RAM,可使用那些寻址方式?答:低 128 字节:直接寻址,位寻址,寄存器间接寻址,寄存器寻址(R0R7)高 128 字节:直接寻址,位寻址,寄存器寻址13、如何访问片内外程序存储器,可使用那些寻址方式?答:采用变址寻址(用MOVC指令)14、说明十进制调整的原因和方法?答:压缩 BCD码在进行加法运算时应逢十进一,而计算机只将其当作十六进制数处理,此时得到的结果不正确。用 DA A 指令调整(加 06H,60H,66H)

27、15、说明 8951 布尔机处理机功能?答:用来进行位操作16、ANLA , #17H;83H 17H=03HAORL17H ,A; 34H03H=37H17HXRLA,R0; 03H37H=34HCPLA; 34H求反等于 CBH所以( A)=CBH17、(1)SETB 或 SETB E0H;E0H是累加器的地址(2)CLRCLRCLRCLR(3)CLRCLRCLRCLR18、MOV 27H, R7MOV 26H,R6MOV 25H,R5MOV 24H,R4MOV 23H,R3MOV 22H,R2MOV 21H,R1MOV 20H,R019、MOV 2FH, 20MOV 2EH , 21MO

28、V 2DH , 2220、编程,进行两个16 位数的减法: 6F5DH-13B4H,结果存入内部 RAM的 30 和 31H单元, 30H 存低八位。CLR CMOV A,#5DH;被减数的低 8 位 AMOV R2, #B4H;减数低 8 位 R2SUBB A, R2;被减数减去减数,差AMOV 30H,A;低 8 位结果 30HMOV A,#6FH;被减数的高 8 位 AMOV R2, #13H;减数高 8 位 R2SUBB A, R2;被减数减去减数,差AMOV 31H,A;高 8 位结果 30H注意:如果在你的程序中用到了进位位,在程序开始的时候要记得清0 进位位21、编程,若累加器A

29、 满足下列条件,则程序转至LABEL存储单元,设 A 中为无符号数。( 1)A 10CJNE A, #0AH,L1;(A)与 10 比较,不等转 L1LJMP LABEL;相等转 LABELL1:JNCLABEL;( A)大于10,转LABEL或者:CLR CSUBB A, #0AHJNCLABEL( 2)A 10CJNE A, #0AH,L1RETL1:JNC LABELRET;(A)与 10 比较,不等转L1;相等结束;( A)大于 10,转 LABEL;(A)小于 10,结束或者:CLR CSUBB A, #0AHJNCL1RETL1:JNZ LABELRET( 3)A 10CJNE A

30、, #0AH,L1;(A)与10 比较,不等转L1L2:LJMP LABELL1:JCL2;相等转 LABEL;(A)小于 10,转 L2RET或者:CLR CSUBB A, #0AHJCLABELJZ LABELRET22、(SP) =23H,(PC) =3412H参看书上 80 页23、(SP) =27H,(26H)=48H,(27H)=23H,(PC)=3456H参看书上 79 页24、不能。 ACALL是短转指令,可调用的地址范围是2KB。在看这个题的时候同时看一下AJMP指令。同时考虑调用指令令和 RET指令的关系。ACALL和LCALL指25、 编程,查找内部 RAM中 20H-5

31、0H 单元中是否有 0AAH这一数据,若有则将 51h 单元置为 01H,如无,则将 51H单元清零。MOV R2 ,#31H;数据块长度 R2MOV R0,#20H;数据块首地址R0LOOP: MOV A, R0;待查找的数据ACLR C;清进位位SUBB A,#0AAH;待查找的数据是0AAH吗JZL1;是,转 L1INC R0;不是,地址增1,指向下一个待查数据DJNZ R2, LOOP;数据块长度减1,不等于 0,继续查找MOV 51H, #00H;等于 0,未找到, 00H51HRETL1: MOV 51H,#01H;找到,01H 51HRET26、编程查找内部RAM的20H-50H

32、 单元中出现00H的次数并将结果存入51H 中。MOV R2,#31H;数据块长度 R2MOV R0,#20H;数据块首地址R0LOOP: MOV A, R0;待查找的数据AJNZ L1;不为 0,转 L1INC 51H;为 0, 00H个数增 1L1: INC R0;地址增 1,指向下一个待查数据DJNZ R2, LOOP;数据块长度减1,不等于0,继续查找RET27、外部数据 RAM中有一个数据块,首地址为 SOURCE,要求将该数据传送到内部RAM以 DIST 开头的区域在,直到遇到数字字符¥时结束。MOV DPTR , #SOURCE;源首地址 DPTRMOV R0,#DIST;目的首

33、地址 R0LOOP: MOVX A,DPTR;传送一个字符MOV R0,AINC DPTR;指向下一个字符INC R0CJNE A, #24H, LOOP;传送的是“ $”字符吗?不是,传送下一个字符RET28、已知 R3和R4中存有一个十六位的二进制数,高位在3 中,低位在4 中,编程求其补,并存回原处。MOV A , R3;取该数高8 位 AANLA,#80H;取出该数符号判断JZ L1;是正数,转L1MOV A,R4;是负数,将该数低8位ACPL A;低 8 位取反ADD A,#01H;加 1MOV R4,A;低 8 位取反加 1 后 R4MOV A,R3;将该数高 8 位 ACPL A

34、;高 8 位取反ADDC A,#00H;加上低 8 位加 1 时可能产生的进位MOV R3,A;高 8 位取反加 1 后 R3L1 : RET29、 已知 30H 和 31H 中存有一个十六位的二进制数,高位在前, 低位在后,编程将它们乘 2,并存回原处。CLR C;清进位位 CMOV A,31H;取该数低 8 位 ARLC A;带进位位左移 1 位MOV 31H,A;结果存回 31HMOV A,30H;取该数高 8 位 ARLC A;带进位位左移 1 位MOV 30H,A;结果存回 30H30、内存中有两个4 字节以压缩的BCD码形式存放的十进制数, 一个放在 30H-33H的单元中,一个放

35、在 40H-43H 的单元中,编程求他们的和,结果放在 30H-33H 的单元中。MOV R2 ,#04H;字节长度 R2MOV R0,#30H;一个加数首地址R0MOV R1,#40H;另一个加数首地址R1CLR C;清进位位LOOP: MOV A, R0;取一个加数ADDC A,R1;两个加数带进位位相加DA A;十进制调整MOV R0, A;存放结果INC R0;指向下一个字节INC R1;DJNZ R2, LOOP;数据块长度减1,不等于RET0,继续查找31、编程,把片外 RAM从 2000H开始存放的8 个数传送到片内MOV R2 ,#08H;数据块长度 R2MOV R0,#30H

36、;数据块目的地址R0MOV DPTR,#2000H;数据块源地址DPTRLOOP: MOVX A, DPTR;传送一个数据30H 开始的单元中。MOV R0, AINC DPTR INC R0 DJNZ R2, LOOP;指向下一个数据;数据块长度减1,没传送完,继续传送RET35、解:(1000H)=53H( 1001H)=54H( 1002H)=41H(1003H)=52H( 1004H)=54H( 1005H) =12H(1006H)=34H( 1007H)=30H( 1008H) =00H(1009H)=70H36、阅读下列程序说明其功能MOVR0,#40H;40HR0MOV A,R0

37、;98H AINCR0;41H R0ADDA ,R0; 98H+( 41H)=47HAINC R0MOVR0,A;结果存入42H单元CLRA;清AADDC A, #0;进位位存入AINC R0MOV R0,A;进位位存入43H功能:将 40H,41H 单元中的内容相加结果放在42H单元,进位放在 43H单元,(R0)=43H,( A)=1,(40H) =98H,(41H) =AFH,(42H)=47H,(43H)=01H37、同上题MOVA,61H; F2H AMOVB,#02H; 02H BMUL AB; F2HO2H=E4HAADD A, 62H;积的低 8 位加上 CCHAMOV 63H

38、,A;结果送 62HCLRA;清AADDC A,B;积的高 8 位加进位位 AMOV 64H,A;结果送 64H功能:将61H 单元的内容乘2,低 8 位再加上62H 单元的内容放入63H,将结果的高 8 位放在 64H单元。(A)=02H,( B)=01H,( 61H)=F2H,( 62H)=CCH,(63H)=B0H,( 64H) =02H39、MOV A,XXHORL A,#80HMOV XXH, A40、(2)MOVA,XXHMOVR0,AXRLA,R0第五章1、什么是中断和中断系统?其主要功能是什么?答:当 CPU正在处理某件事情的时候,外部发生的某一件事件请求 CPU迅速去处理,于

39、是, CPU 暂时中止当前的工作,转去处理所发生的事件,中断服务处理完该事件以后,再回到原来被终止的地方,继续原来的工作。这种过程称为中断,实现这种功能的部件称为中断系统。功能:( 1)使计算机具有实时处理能力,能对外界异步发生的事件作出及时的处理( 2)完全消除了CPU在查询方式中的等待现象,大大提高了CPU的工作效率( 3)实现实时控制2、试编写一段对中断系统初始化的程序,使之允许 INT0, INT1, TO,串行口中断,且使 T0 中断为高优先级中断。解: MOVIE,#097HMOVIP,#02H3、在单片机中,中断能实现哪些功能?答:有三种功能:分时操作,实时处理,故障处理4、89

40、C51共有哪些中断源?对其中端请求如何进行控制?答:(1) 89C51有如下中断源 : 外部中断 0 请求,低电平有效 : 外部中断 1 请求,低电平有效 T0:定时器、计数器 0 溢出中断请求 T1:定时器、计数器 1 溢出中断请求 TX/RX:串行接口中断请求( 2)通过对特殊功能寄存器 TCON、SCON、IE 、IP 的各位进行置位或复位等操作,可实现各种中断控制功能5、什么是中断优先级?中断优先处理的原则是什么?答:中断优先级是 CPU相应中断的先后顺序。原则:( 1)先响应优先级高的中断请求,再响应优先级低的( 2)如果一个中断请求已经被响应,同级的其它中断请求将被禁止( 3) 如

41、果同级的多个请求同时出现,则 CPU通过内部硬件查询电路,按查询顺序确定应该响应哪个中断请求查询顺序:外部中断 0定时器 0 中断外部中断 1定时器 1 中断串行接口中断6、说明外部中断请求的查询和响应过程。答:当 CPU执行主程序第 K 条指令,外设向 CPU发出中断请求, CPU接到中断请求信号并在本条指令执行完后,中断主程序的执行并保存断点地址,然后转去响应中断。 CPU在每个S5P2 期间顺序采样每个中断源,CPU在下一个机器周期S6期间按优先级顺序查询中断标志,如果查询到某个中断标志为 1,将在接下来的机器周期 S1 期间按优先级进行中断处理, 中断系统通过硬件自动将相应的中断矢量地

42、址装入 PC,以便进入相应的中断服务程序。中断服务完毕后, CPU返回到主程序第 K+1 条指令继续执行。7、89C51在什么条件下可响应中断?答:( 1)有中断源发出中断请求( 2)中断中允许位 EA=1.即 CPU开中断( 3)申请中断的中断源的中断允许位为1,即中断没有被屏蔽( 4)无同级或更高级中断正在服务( 5)当前指令周期已经结束( 6) 若现行指令为 RETI 或访问 IE 或 IP 指令时,该指令以及紧接着的另一条指令已执行完毕8、简述 89C51 单片机的中断响应过程。答: CPU在每个机器周期 S5P2期间顺序采样每个中断源, CPU在下一个机器周期S6 期间按优先级顺序查

43、询中断标志,如查询到某个中断标志为 1,将在接下来的机器周期 S1 期间按优先级进行中断处理, 中断系统通过硬件自动将相应的中断矢量地址装入 PC,以便进入相应的中断服务程序。一旦响应中断, 89C51首先置位相应的中断“优先级生效”触发器,然后由硬件执行一条长调用指令,把当前的PC值压入堆栈,以保护断点,再将相应的中断服务的入口地址送入PC,于是 CPU接着从中断服务程序的入口处开始执行。对于有些中断源, CPU在响应中断后会自动清除中断标志。9、在 89C51内存中,应如何安排程序区?答:主程序一般从 0030H开始,主程序后一般是子程序及中断服务程序。在这个大家还要清除各个中断的中断矢量

44、地址。10、试述中断的作用及中断的全过程。答:作用:对外部异步发生的事件作出及时的处理过程:中断请求,中断响应,中断处理,中断返回11、当正在执行某一个中断源的中断服务程序时,如果有新的中断请求出现,试问在什么情况下可响应新的中断请求?在什么情况下不能响应新的中断请求?答:(1)符合以下6 个条件可响应新的中断请求:a) 有中断源发出中断请求b) 中断允许位 EA=1,即 CPU开中断c) 申请中断的中断源的中断允许位为 1,即中断没有被屏蔽 d) 无同级或更高级中断正在被服务e) 当前的指令周期已结束f) 若现行指令为 RETI 或访问 IE 或 IP 指令时,该指令以及紧接着的另一条指令已

45、被执行完12、89C51单片机外部中断源有几种触发中断请求的方法?如何实现中断请求?答:有两种方式:电平触发和边沿触发电平触发方式: CPU在每个机器周期的 S5P2期间采样外部中断引脚的输入电平。若为低电平,使IE1(IE0)置“ 1”,申请中断;若为高电平,则IE1(IE0)清零。边沿触发方式: CPU在每个机器周期S5P2期间采样外部中断请求引脚的输入电平。如果在相继的两个机器周期采样过程中,一个机器周期采样到外部中断请求为高电平,接着下一个机器周期采样到外部中断请求为低电平,则使IE1(IE0)置“1”申请中断;否则,IE1(IE0)置 0。13、89C51 单片机有五个中断源,但只能

46、设置两个中断优先级,因此,在中断优先级安排上受到一定的限制。试问以下几种中断优先顺序的安排(级别由高到低)是否可能:若可能,则应如何设置中断源的中断级别:否则,请简述不可能的理由。定时器 0,定时器 1,外中断 0,外中断 1,串行口中断。可以, MOV IP,#0AH串行口中断,外中断0,定时器0,外中断1,定时器1。可以, MOVIP,#10H外中断 0,定时器 1,外中断 1,定时器 0,串行口中断。不可以,只能设置一级高级优先级,如果将INT0,T1 设置为高级,而T0 级别高于 INT1.外中断 0,外中断 1,串行口中断,定时器 0,定时器 1 。可以, MOVIP,#15H串行口

47、中断,定时器0,外中断 0,外中断 1,定时器 1。不可以外中断 0,外中断 1,定时器 0,串行口中断,定时器1 。 不可以外中断0,定时器1,定时器0,外中断1,串行口中断。可以,MOVIP,#09H14、89C51各中断源的中断标志是如何产生的?又是如何清0 的? CPU响应中断时,中断入口地址各是多少?答:各中断标志的产生和清“0”如下:( 1)外部中断类外部中断是由外部原因引起的,可以通过两个固定引脚,即外部中断0 和外部中断 1 输入信号。外部中断 0 请求信号,由脚输入。通过IT0 来决定中断请求信号是低电平有效还是下跳变有效。一旦输入信号有效,则向CPU申请中断,并且使IE0=

48、1。硬件复位。外部中断 1 请求信号,功能与用法类似外部中断0( 2)定时中断类定时中断是为满足定时或计数溢出处理需要而设置的。当定时器 / 计数器中的计数结构发生计数溢出的,即表明定时时间到或计数值已满,这时就以计数溢出信号作为中断请求,去置位一个溢出标志位。这种中断请求是在单片机芯片内部发生的,无需在芯片上设置引入端,但在计数方式时,中断源可以由外部引入。TF0:定时器 T0 溢出中断请求。当定时器 T0 产生溢出时,定时器 T0 请求标志 TF0=1,请求中断处理。使用中断时由硬件复位,在查询方式下可由软件复位。TF1:定时器 T1 溢出中断请求。功能与用法类似定时器T0( 3)串行口中断类串行口中断是为串行数据的传送需要而设置的。串行中断请求也是在单片机芯片内部发生的, 但当串行口作为接收端时,必须有一完整的串

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论