单片机与微机原理及应用课后答案张迎新等电子工业出版社Word文档下载推荐.docx

上传人:b****3 文档编号:17547713 上传时间:2022-12-07 格式:DOCX 页数:7 大小:25.38KB
下载 相关 举报
单片机与微机原理及应用课后答案张迎新等电子工业出版社Word文档下载推荐.docx_第1页
第1页 / 共7页
单片机与微机原理及应用课后答案张迎新等电子工业出版社Word文档下载推荐.docx_第2页
第2页 / 共7页
单片机与微机原理及应用课后答案张迎新等电子工业出版社Word文档下载推荐.docx_第3页
第3页 / 共7页
单片机与微机原理及应用课后答案张迎新等电子工业出版社Word文档下载推荐.docx_第4页
第4页 / 共7页
单片机与微机原理及应用课后答案张迎新等电子工业出版社Word文档下载推荐.docx_第5页
第5页 / 共7页
点击查看更多>>
下载资源
资源描述

单片机与微机原理及应用课后答案张迎新等电子工业出版社Word文档下载推荐.docx

《单片机与微机原理及应用课后答案张迎新等电子工业出版社Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《单片机与微机原理及应用课后答案张迎新等电子工业出版社Word文档下载推荐.docx(7页珍藏版)》请在冰豆网上搜索。

单片机与微机原理及应用课后答案张迎新等电子工业出版社Word文档下载推荐.docx

6、89S51/52的时钟周期、机器周期、指令周期是如何分配的当振荡频率为8MHz时,一个单片机周期为多少微秒答:

时钟周期为时钟脉冲频率的倒数,他是单片机中最基本的、最小的时间单位。

机器周期是指完成一个基本操作所需要的时间,一个机器周期由12个时钟周期组成。

指令周期是执行一条指令所需要的时间,由若干个机器周期组成。

若fosc=8MHz,则一个机器周期=1/8×

12μs=μs7、89S51/52扩展系统中,片外程序存储器和片外数据存储器共处同一地址空间为什么不会发生总线冲突答:

访问片外程序存储器和访问数据存储器使用不同的指令用来区分同一地址空间。

8、程序状态字寄存器PSW的作用是什么常用状态标志有哪些位作用是什么答:

程序状态字PSW是8位寄存器,用于存放程序运行的状态信息,PSW中各位状态通常是在指令执行的过程中自动形成的,但也可以由用户根据需要采用传送指令加以改变。

各个标志位的意义如下:

(Cy):

进位标志位。

(AC):

辅助进位标志位,又称为半进位标志位。

(F0):

用户标志位。

、(RS1和RS0):

寄存器组选择位。

(OV):

溢出标志位。

(空缺位):

此位未定义。

(P):

奇偶校验位。

9、位地址7CH和字节地址7CH有何区别位地址7CH具体在内存中什么位置答:

字节地址7CH是片内数据存储器中的一个地址单元,该地址单元中可以存放8位二进制数,位地址7CH是内部数据存储器中位寻址区中的一位,该地址单元中可以存放1位二进制数。

位地址7CH具体在片内数据存储器字节地址为2FH中的第4位()。

10、89S51/52中4个I/O端口的作用是什么89S51/52的片外三总线是如何分配的答:

I/O端口是单片机与外界联系的重要通道,实现与外部设备的信息的传输。

总线分配:

片外数据总(8根)通过P0口输出,片外地址总线(16根)通过P0口(低8位)和P2口(高8位)输出,片外控制总线(PSEN,ALE,RD,WR,EA)主要通过P3口。

11、89S51/52中4个I/O端口在结构上有何异同89S51/52单片机的4个I/O口在结构上是基本相同的,但又各具特点。

这四个端口都是8位双向口,每个端口都包括一个锁存器、一个输出驱动器和输入缓冲器。

在无片外扩展存储器的系统中,这四个端口的每一位都可以作为双向通用I/O端口使用。

在作为一般的通用I/O输入时,都必须先向锁存器写入“1”,使输出驱动场效应管FET截止,以免误读数据。

各自特点如下:

(1)P0口为双向8位三态I/O口,它既可作为通用I/O口,又可作为外部扩展时的数据总线及低8位地址总线的分时复用口。

作为通用I/O口时,输出数据可以得到锁存,不需外接专用锁存器;

输入数据可以得到缓冲,增加了数据输入的可靠性。

每个引脚可驱动8个TTL负载。

(2)P1口为8位准双向I/O口,内部具有上拉电阻,一般作通用I/O口使用,它的每一位都可以分别定义为输入线或输出线,作为输入时,锁存器必须置1。

每个引脚可驱动4个TTL负载。

(3)P2口为8位准双向I/O口,内部具有上拉电阻,可直接连接外部I/O设备。

它与地址总线高8位复用,可驱动4个TTL负载。

一般作为外部扩展时的高8位地址总线使用。

(4)P3口为8位准双向I/O口,内部具有上拉电阻,它是双功能复用口,每个引脚可驱动4个TTL负载。

作为通用I/O口时,功能与P1口相同,常用第二功能。

12、复位的作用是什么有几种复位方法复位后单片机的状态如何答:

复位是单片机的初始化操作。

单片机在RST引脚产生两个机器周期(即24个时钟周期)以上的高电平即可实现复位。

主要的复位方法有上电自动复位和按键手动复位两种。

按键手动复位又分:

按键电平复位和按键脉冲复位。

 

第三章第三章指令系统

1、简述下列名词术语的基本概念:

指令、指令系统、程序、汇编语言指令答:

指令:

规定单片机进行某种操作的命令称为指令。

指令系统:

单片机能够执行的各种指令的集合。

程序:

一系列指令的有序集合称为程序。

汇编语言指令:

用助记符形式来表示机器指令。

2、2、80C51单片机有哪几种寻址方式这几种寻址方式是如何寻址的答:

共7种寻址方式,分别为:

寄存器寻址,直接寻址,寄存器间接寻址,立即寻址,变址寻址,位寻址和相对寻址。

寄存器寻址方式:

由指令指出某一寄存器的内容做为操作数。

直接寻址方式:

指令中操作数直接以单元地址的形式给出。

寄存器间接寻址方式:

寄存器中存放的是操作数,而寄存器间接寻址方式,寄存器中存放的则是操作数的地址,即操作数是通过寄存器间接得到的。

立即寻址方式:

操作数在指令中直接给出。

变址寻址方式:

变址寻址是为了访问程序存储器中的数据和表格。

MCS-51的变址寻址是以DPTR或PC作基址寄存器,以累加器A作变址寄存器,并以两者内容相加形成的16位地址做为操作数地址,以达到访问数据和表格的目的。

位寻址方式:

指对片内RAM的位寻址区和某些可寻址的特殊功能寄存器进行位操作的寻址方式。

相对寻址方式:

相对寻址方式是为解决程序转移而专门设置的,为转移指令所采用。

3、要访问特殊功能寄存器和片外数据寄存器,应采用哪些寻址方式答:

访问特殊功能寄存器可以采用直接寻址、立即寻址、寄存器寻址和位寻址(针对可以进行位寻址的特殊功能寄存器)方式。

访问片外数据存储器可采用寄存器间接寻址方式。

4、80C51单片机的指令系统可以分为哪几类说明各指令的功能。

答:

51单片机指令系统按功能可分为5类:

(1)数据传送指令主要进行数据的传送、交换等;

(2)算术运算指令主要进行基本的加减乘除运算;

(3)逻辑运算指令主要实现逻辑运算与移位运算;

(4)控制转移指令主要是实现对程序流程的控制;

(5)位操作指令

5、外部数据传送指令有哪几条有和区别答:

外部数据传送指令有读指令和写指令两类,每类指令的寻址范围不同,分别为:

读外部存储器指令:

MOVXA,@Ri;

寻址范围为256字节MOVXA,@DPTR;

寻址范围为64K字节写外部存储器指令:

MOVX@Ri,A;

寻址范围为256字节MOVX@DPTR,A;

寻址范围为64K字节

6、在89S51片内RAM中,已知(30H)=38H,(38H)=40H,(40H)=48H,(48H)=90H,请分别分析下段程序按序执行后的结果。

MOVA,40H;

A=48HMOVR0,A;

R0=48HMOVP1,#0FFH;

P1=FFHMOV@R0,30H;

(48H)=38HMOVDPTR,#1246H;

DPTR=1246HMOV40H,38H;

(40H)=40HMOVR0,30H;

R0=38HMOV90H,R0;

(90H)=38HMOV48H,#30H;

(48H)=30HMOVA,@R0;

A=40HMOVP2,P1;

P2=38H

7、略

8、DAA指令的作用是什么怎样使用答:

对十进制BCD数作加法时进行调整,当结果的低4位A0~A3>

9,或半进位AC=1,则A0~A3+6,否则不加;

当结果的高4位A4~A7>

9,或进位CY=1,则A4~A7+6,否则不加;

这条指令是在进行BCD码加法运算时,跟在“ADD”和“ADDC”指令之后,用来对BCD码的加法运算结果自动进行修正,使其仍为BCD码表示形式。

9、试编程将片外数据存储器60H中的内容传送到片内RAM54H单元中。

MOVR0,#60HMOVXA,@R0MOV54H,A

10、试编程将寄存器R7的内容传送到R1中去。

MOVA,R7MOVR1,A

11、已知当前PC值为210H,请用两种方法将程序存储器2F0H中的常数送入累加器A中。

(1)以程序计数器PC作为基址寄存器MOVA,#0E0HMOVCA,@A+PC

(2)以数据指针DPTR作为基址寄存器MOVDPTR,#02F0HMOVA,#00HMOVCA,@A+DPTR

12、试说明下段程序中每条指令的作用,并分析当指令执行完后,R0中的内容是什么MOVR0,#0A7H;

R0=A7H,立即数送寄存器R0XCHA,R0;

A=A7H,累加器A中的数据与R0中的数据进行交换SWAPA;

A=7AH,累加器A中的高低四位进行交换XCHA,R0;

R0=7AH,数据交换回R0

13、请用两种方法实现累加器A与寄存器B的内容交换。

(1)MOVR0,AMOVA,BMOVB,R0

(2)MOVR0,BXCHA,R0

14、试编程将片外RAM中40H单元的内容与R1的内容交换。

MOVR0,#40HMOVXA,@R0XCHA,R1MOVX@R0,A

15、已知:

A=0C9H,B=8DH,CY=1。

执行指令ADDCA,B结果如何A=57H,CY=1,OV=1,AC=1,P=1执行指令SUBBA,B结果如何A=3BH,CY=0,AC=1,OV=1

16、试编程将片外RAM中30H和31H内容相乘,结果存放在32H(低位)和33H(高位)单元中。

MOVR0,#30HMOVXA,@R0MOVB,AINCR0MOVXA,@R0MULABINCR0MOVX@R0,AMOVA,BINCR0MOVX@R0,A

17、17、试用3种方法将累加器A中的无符号数乘2.答:

(1)MOVR0,AADDA,R0

(2)MOVB,#2MULAB(3)RLA

18、18、分析依次执行下列指令的结果:

MOV30H,#0A4H;

(30H)=A4HMOVA,#0D6H;

A=D6HMOVR0,#30H;

R0=30HMOVR2,#47H;

R2=47HANLA,R2;

A=46HORLA,@R0;

A=E6HSWAPA;

A=6EHCPLA;

A=91HXRLA,#0FFH;

A=6EHORL30H,A;

(30H)=EEH

19、19、求下列指令执行后,累加器A及PSW中进位CY、奇偶位P和溢出位OV的值。

(1)当A=5BH时;

ADDA,#8CH

(2)当A=5BH时;

ANLA,#7AH(3)当A=5BH时;

XRLA,#7FH(4)当A=5BH,CY=1时;

SUBBA,#0E8H答:

(1)A=E7H,CY=1,P=0,OV=0

(2)A=5AH,P=0(3)A=24H,P=0(4)A=72H,CY=1,P=0,OV=020、把累加器A中的低4位数据送到外部数据存储器的2000H单元。

ANLA,#OFHMOVDPTR,#2000HMOVX@DPTR,A21、试说明指令CJNE@R1,#7AH,10H的作用,若本指令地址为250H,其转移地址是多少答:

指令作用:

如果以R1内容为地址的单元中的数据等于7AH,则程序顺序执行,否则转移后继续执行。

若本指令地址为250H,则转移地址为250H+03H+10H=263H。

22、将累加器A中的数据由0递增,加到50,结果在累加器A中。

CLRAMOVR0,#50L1:

INCADJNZR0,L123、试说明压栈指令和弹栈指令的作用及执行过程。

压栈(入栈或进栈)指令的作用是将数据存入堆栈中,其执行过程是先将堆栈指针SP的内容加1,然后将直接地址单元中的数据压入SP指向的单元中。

若数据已推入堆栈,则SP指向最后推入数据所在的存储单元(即指向栈顶)。

弹栈(出栈)指令的作用是将数据从堆栈中取出,其执行过程为先将堆栈指针SP所指出单元的内容送入直接寻址单元中,然后将SP的内容减1,此时SP指向新的栈顶。

24、下述程序执行后,SP=,A=,B=。

ORG201HMOVSP,#40HMOVA,#30HLCALL250H;

下条指令地址208H送41H、42H,SP=42HADDA,#10HMOVB,A;

地址为20AHL1:

SJMPL1ORG250HMOVDPTR,#20AHPUSHDPL;

SP+1=43H,DPL→(43H)PUSHDPH;

SP+1=44H,DPH→(44H)RET;

20AH→PC答:

上述程序执行后,SP=42H,A=30H,B=30H。

25、发光二极管点亮规律:

先是第1和第8个亮,延时一段时间后,第2和第7个亮,延时后,再是第3和第6个亮,延时后,最后是第4和第5个点亮,延时后循环。

26、若系统晶振频率为6MHz,求子程序DELAY的延时时间,若想加长或缩短时间,应该怎样修改答:

DELAY:

MOVR2,#0FAHL1:

MOVR3,#0FAHL2:

DJNZR3,L2DJNZR2,L1RET总时间计算:

T=4μs+(250×

4μs+4μs)×

250+4μs=估算:

T=250×

4μs×

250=250ms若想加长延时时间,可以增加循环次数或再加一重循环;

若想减小延时时间,可以减少循环次数或较少一重循环。

27、P1口连接8个共阳极连接的发光二极管,是编制灯亮移位程序。

MOVA,#0FEHL1:

MOVP1,ARLALCALLDELAY;

DELAY子程序同上题SJMPL128、试编一程序,将外部数据存储器2100H单元中的高4位置“1”,其余位清“0”。

MOVDPTR,#2100HMOVXA,@DPTRORLA,#0F0HANLA,#0F0HMOVX@DPTR,A29、试编程将片内数据存储器40H单元的第0为和第7位置1,其余取反。

MOVA,40HCPLASETBSETBMOV40H,A30、将与80H位相与的结果,通过输出。

MOVC,80HANLC,MOV,C31、请用位操作指令,求下列逻辑方程。

(1)MOVC,ORLC,ANLC,ORLC,/MOV,C

(2)MOVC,ANLC,MOV20H,CMOVC,ANLC,/ORLC,20HMOV,C(3)MOVC,ANLC,/MOV20H,CMOVC,ANLC,/ORLC,20HMOV,C

第四章汇编语言程序设计1、编程将片内40H~60H单元中的内容送到以3000H为首的存储区内。

MOVR1,#40HMOVR2,#21HMOVDPTR,#3000HL1:

MOVA,@R1MOVX@DPTR,AINCR1INCDPTRDJNZR2,L12、编程计算下列算式的程序

(1)23H+45H+ABH+03H=MOVA,#23HADDA,#45HADDA,#0ABHXCHA,B;

溢出处理ADDCA,#00HXCHA,BADDA,#03H;

A中为结果低位,B中为高位

(2)CDH+15H-38H-46H=MOVA,#0CDHADDA,#15HSUBBA,#38HSUBBA,#46H(3)1234H+8347H=MOVA,#34HADDA,#47HMOV30H,AMOVA,#12HADDCA,#83HMOV31,A;

30H存结果低位,31H存结果高位(4)AB123H-43ADCH=CLRCMOVA,#23HSUBBA,DCHMOV30H,AMOVA,#0B1HSUBBA,#3AHMOV31H,AMOVA,#0AHSUBBA,,#04HMOV32H,A;

30H为低位,32H为高位3、设有两个4位BCD码,分别存放在23H、22H单元和33H、32H单元中,求他们的和,并送入43H、42H单元中(低位在低字节,高位在高字节)。

MOVA,22HADDA,32HDAAMOV42H,AMOVA,23HADDCA,33HDAAMOV43H,A4、略5、编程计算片内RAM区50H~59H单元中数的平均值,结果存放在5AH中。

MOVR0,#8MOVR1,#50HMOVA,#00HL1:

ADDA,@R1INCR1DJNZR0,L1MOVB,#8DIVABMOV5AH,A6、编写计算下式的程序。

设乘积和平方结果均小于255。

a、b值分别存在片外3001H和3002H单元中,结果存于片外3000H单元中。

(1)MOVDPTR,#3001HMOVXA,@DPTRMOV30H,A;

a暂存30H单元INCDPLMOVXA,@DPTRCJNEA,30H,L1;

是否a=bMOVA,#25SJMPSAVEL1:

JNCL2MOVB,30HMULABSJMPSAVEL2:

MOVB,AMOVA,30HDIVABSAVE:

MOVDPTR,#3000HMOVX@DPRT,A

(2)MOVDPTR,#3001HMOVXA,@DPTRMOV30H,AINCDPTRMOVXA,@DPTRADDA,30HMOVB,AMULAB;

(a+b)2MOV31H,ACJNEA,#10,L1SJMPSAVEL1:

JCL2CLRCSUBBA,#10SJMPSAVEL2:

ADDA,#10SAVE:

MOVDPTR,#3000HMOVC@DPTR,A7、设有两个长度均为15的数组,分别存放在以200H和210H为首地址的存储区中,试编程求其对应项之和,结果存放到以220H为首地址的存储区中。

MOVDPH,#02HMOVR1,#15MOVR2,#00H;

数组1首地址低位MOVR3,#10H;

数组2首地址低位MOVR4,#20H;

和首地址低位L1:

MOVDPL,R2MOVXA,@DPTRMOVR1,AMOVDPL,R3MOVXA,@DPTRADDA,R1MOVDPL,R4MOVX@DTPR,AINCR2INCR3INCR4DJNZR1,L1SJMP$8、设有100个无符号数,连续存放在以2000H为首地址的存储区中,试编程统计正数、负数和零的个数。

MOV30H,#00H;

正数计数器MOV31H,#00H;

负数计数器MOV32H,#00H;

零计数器MOVDPTR,#2000HMOVR1,#100L4:

MOVXA,@DPTRINCDPTRCJNEA,#0,L1INC32HSJMPL2L1:

JCL3INC30HSJMPL2L3:

INC31HL2:

DJNZR1,L4SJMP$9、将片外数据存储器地址为1000H~1030H的数据块,全部搬迁到片内RAM30H~60H中,并将原数据块区域全部清零。

MOVR0,#30HMOVR2,#31HMOVDPTR,#1000HLP:

MOVXA,@DPTRMOV@R0,AANDA,#00HMOVX@DPTR,AINCR0INCDPTRDJNZR2,LPSJMP$10、试编写一子程序,是R1、R0指向的两个片外RAM连续单元中的高4位二进制数,合并成一个字节,装入累加器A中。

已知R0指向低地址,并要求该单元高四位放在A中高四位。

MOVXA,@R1ANLA,#0F0HSWAPAMOVR2,AMOVXA,@R0ANLA,#0F0HORLA,R211、试编程把以2040H为首地址的连续50个单元的无符号数按降序排列,存放到以3000H为首地址的存储区中。

MOVR2,#50MOVR3,#20HMOVR4,#40H;

源地址MOVR5,#30HMOVR6,#00H;

目的地址SEND:

MOVDPH,R3;

SEND将2040H数据块移入3000H存储区MOVDPL,R4MOVXA,@DPTRINCDPTRMOVR3,DPHMOVR4,DPLMOVDPH,R5MOVDPL,R6MOVX@DPTR,AINCDPTRMOVR5,DPHMOVR6,DPLDJNZR2,SENDMOVR2,#49;

重复次数CMP1:

MOVDPTR,#3000HMOVR3,#49;

比较次数CMP2:

MOVXA,@DPTRMOVB,AINCDPTRMOVXA,@DPTRCJNEA,B,L1L1:

JCNOMOVEMOV30H,ACLRCMOVA,DPLSUBBA,#01HMOVDPL,AMOVA,30HMOVX@DPTR,AINCDPTRMOVA,BMOVX@DP

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 外语学习 > 韩语学习

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1