ImageVerifierCode 换一换
格式:DOCX , 页数:26 ,大小:42.90KB ,
资源ID:17383897      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/17383897.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(《微机原理与接口技术》冯博琴清华出版社课后答案Word下载.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

《微机原理与接口技术》冯博琴清华出版社课后答案Word下载.docx

1、(2)001000111.8 已知 X= -1101001B,Y= -1010110B,用补码求 X-Y 的值。111011011.9 请写出下列字符的 ASCII 码。4A3-!34H,41H,33H,3DH,21H1.10 若给字符 4 和 9 的 ASCII 码加奇校验,应是多少?34H,B9H1.11 上题中若加偶校验,结果如何?B4H,39H1.12 计算下列表达式。(1) (4EH+10110101B)x(0.0101)BCD=( )D(2)4EH-(24/08H+B/2)=( )B(1) 129.5D(2)101010B第 2 章 微型计算机基础2.6 简述 CPU 执行程序的过

2、程。当程序的第一条指令所在的地址送入程序计数器后,CPU 就进入取指阶段准备取第一条指令。在取指 阶段,CPU 从内存中读出指令,并把指令送至指令寄存器 IR 暂存。在取指阶段结束后,机器就进入执行 阶段,这时,由指令译码器对指令译码,再经控制器发出相应的控制信号,控制各部件执行指令所规定的 具体操作。当一条指令执行完毕以后,就转入了下一条指令的取指阶段。以上步骤周而复始地循环,直到 遇到停机指令。2.7 说明 8086 的 EU 和 BIU 的主要功能。在执行程序过程中他们是如何相互配合工作的?执行单元 EU 负责执行指令。EU 在工作时不断地从指令队列取出指令代码,对其译码后产生完成指令

3、所需要的控制信息。数据在 ALU 中进行运算,运算结果的特征保留在标志寄存器 FLAGS 中。总线接口单 元 BIU 负责 CPU 与存储器、I/O 接口之间的信息传送。BIU 取出的指令被送入指令队列供 EU 执行,BIU 取出的数据被送入相关寄存器中以便做进一步的处理。当 EU 从指令队列中取走指令,指令队列出现空字节时,BIU 就自动执行一次取指令周期,从内存中取出后续的指令代码放入队列中。当 EU 需要 数据时,BIU 根据 EU 给出的地址,从指定的内存单元或外设中取出数据供 EU 使用。当运算结束时,BIU 将运算结果送入指定的内存单元或寄存器。当指令队列空时,EU 就等待,直到有

4、指令为止。若 BIU 正在 取指令,EU 发出访问总线的请求,则必须等 BIU 取指令完毕后,该请求才能得到响应。一般情况下,程 序顺序执行,当遇到跳转指令时,BIU 就使指令队列复位,从新地址取出指令,并立即传送 EU 去执行。指令队列的存在使 8086/8088 的 EU 和 BIU 并行工作,从而减少了 CPU 为取指令而等待的时间,提高 了 CPU 的利用率,加快了整机的运行速度。另外也降低了对存储器存取速度的要求。2.8 在执行指令期间,BIU 能直接访问存储器吗?为什么?解:可以.因为 EU 和 BIU 可以并行工作,EU 需要的指令可以从指令队列中获得,这时 BIU 预先从存储器

5、中取 出并放入指令队列的。在 EU 执行指令的同时,BIU 可以访问存储器取下一条指令或指令执行时需要的数 据。2.9 8086 与 8088CPU 的主要区别有哪些?主要区别有以下几点:8086 的外部数据总线有 16 位,而 8088 的外部数据总线只有 8 位。8086 指令队列深度为 6 个字节,而 8088 的指令队列深度为 4 个字节.因为 8086 的外部数据总线有 16 位,故 8086 每个总线周期可以存取两个字节.而 8088 的外部数据总线因为 只有 8 位,所以每个总线周期只能存取 1 个字节.个别引脚信号的含义稍有不同.2.10 8088CPU 工作在最小模式下:(1

6、)当 CPU 访问存储器时,要利用哪些信号?(2)当 CPU 进行 I/O 操作时,要利用哪些信号?(3)当 HOLD 有效并得到响应时,CPU 的哪些信号置高阻?(1)要利用信号线包括 WR#、RD#、IO/M#、ALE 以及 AD0AD7、A8A19。(2)同(1)。(3)所有三态输出的地址信号、数据信号和控制信号均置为高阻态。2.11 总线周期中,什么情况下要插入 TW 等待周期?插入 TW 周期的个数,取决于什么因素?在每个总线周期的 T3 的开始处若 READY 为低电平,则 CPU 在 T3 后插入一个等待周期 TW。在 TW 的开始时刻,CPU 还要检查 READY 状态,若仍为

7、低电平,则再插入一个 TW 。此过程一直进行到某个 TW 开始时,READY 已经变为高电平,这时下一个时钟周期才转入 T4。可以看出,插入 TW 周期的个数取决于 READY 电平维持的时间。2.12 若 8088 工作在单 CPU 方式下,在教材第 91 页的表中填入不同操作时各控制信号的状态。结果如表所示。2.13 在 8086/8088 CPU 中,标志寄存器包含哪些标志位?各位为 0(为 1)分别表示什么含义?(略),见书第 49 页。2.14 8086/8088 CPU 中,有哪些通用寄存器和专用寄存器?说明它们的作用。通用寄存器包含以下 8 个寄存器:AX、BX、CX 和 DX

8、寄存器一般用于存放参与运算的数据或运算的结果。除此之外: AX:主要存放算术逻辑运算中的操作数,以及存放 I/O 操作的数据。 BX:存放访问内存时的基地址。CX:在循环和串操作指令中用作计数器。DX:在寄存器间接寻址的 I/O 指令中存放 I/O 地址。在做双字长乘除法运算时,DX 与 AX 合起来存放一 个双字长数。SP:存放栈顶偏移地址。BP:SP 和 BP 也可以存放数据,但它们的默认段寄存器都是 SS。 SI:常在变址寻址方式中作为源地址指针。 DI:常在变址寻址方式中作为目标地址指针。专用寄存器包括 4 个段寄存器和两个控制寄存器: CS:代码段寄存器,用于存放代码段的段基地址。

9、DS:数据段寄存器,用于存放数据段的段基地址。 SS:堆栈段寄存器,用于存放堆栈段的段基地址。 ES:附加段寄存器,用于存放附加段的段基地址。 IP:指令指针寄存器,用于存放下一条要执行指令的偏移地址。 FLAGS:标志寄存器,用于存放运算结果的特征。2.15 8086/8088 系统中,存储器为什么要分段?一个段最大为多少个字节?最小为多少个字节?分段的主要目的是便于存储器的管理,使得可以用 16 位寄存器来寻址 20 位的内存空间。一个段最大 为 64KB,最小为 16B。2.16 在 8086/8088 CPU 中,物理地址和逻辑地址是指什么?已知逻辑地址为 1F00:38A0H,如何计

10、算出 其对应的物理地址?物理地址时 CPU 存取存储器所用的地址。逻辑地址是段和偏移地址形式的地址,即汇编语言程序中使 用的存储器地址。若已知逻辑地址为 1F00:38A0H,则对应的物理地址=1F00H x 16+38A0H=228A0H。2.17 已知存储器物理地址为 78A00H,计算出它所对应的逻辑地址。此结果惟一吗?物理地址可以对应于不同的逻辑地址。78A00H 对应的逻辑地址可以是 7000H:8A00H,7800H:0A00H,78A0H:0000H 等。结果不是惟一的。2.18 设当前数据段位于存储器的 A8000HB7FFFH,DS 段寄存器的内容应是什么?因为 A8000H

11、 到 B7FFFH 之间的地址范围大小为 64KB,未超出一个段的最大范围。故要访问此地址范 围的数据,数据段的起始地址(即段首地址)应为 A8000H,则 DS 段寄存器为 A800H。2.19 若 CS=8000H,则当前代码段可寻址的存储空间的范围是多少? 解(CS)=8000H 时,当前代码段可寻址的存储空间范围为 80000H8FFFFH。2.20 8086/8088 CPU 在最小模式下构成计算机系统至少应包括哪几个基本部分(器件)?其至少应包括:8088CPU、8284 时钟发生器、8282 锁存器(3 片)和 8286 双向总线驱动器。 第 3 章 8088/8086 指令系统

12、3.1 什么叫寻址方式?8086/8088CPU 共有哪几种寻址方式?寻址方式主要是指获得操作数所在地址的方法. 8086/8088CPU 具有:立即寻址、直接寻址、寄存器寻 址、寄存器间接寻址、寄存器相对寻址、基址一变址寻址、基址一变址相对寻址以及隐含寻址等 8 种寻 址方式。3.2 设(DS)=6000H,(ES)=2000H,(SS)=1500H,(Si)=00A0H,(BX)=0800H,(BP)=1200H,数据变量 VAR为 0050H. 请分别指出下列各条指令源操作数的寻址方式?它的物理地址是多少?(1) MOV AX,BX (2) MOV DL,80H(3) MOV AX, V

13、AR (4) MOV AX,VARBXSI (5) MOV AL,B (6) MOV DI, ES: BX(7) MOV DX,BP (8) MOV BX,20HBX(1)寄存器寻址。因源操作数是寄存器,故寄存器 BX 就是操作数的地址. (2)立即寻址。操作数 80H 存放于代码段中指令码 MOV 之后。 (3)直接寻址。(4)基址一变址一相对寻址 操作数的物理地址=(DS) 16(SI)(BX)VAR= 60000H00A0H0800H0050H608F0H (5)立即寻址(6)寄存器间接寻址.操作数的物理地址= (ES) 16(BX)= 20000H0800H = 20800H(7)寄存

14、器间接寻址。操作数的物理地址= (SS) 16(BP)= 15000H1200H= 16200H(8)寄存器相对寻址操作数的物理地址(DS) 16(BX)20H= 60000H0800H20H= 60820H3.3 假设(DS)= 212AH,(CS)= 0200H,(IP)= 1200H,(BX)= 0500H,位移量 DATA=40H,(217A0H) =2300H,(217E0H)=0400H,(217E2H) =9000H试确定下列转移指令的转移地址. (1) JMP 2300H(2) JMP WORD PTRBX(3) JMP DWORD PTRBX+DATA转移指令分为段内转移和段

15、间转移,根据其寻址方式的不同,又有段内的直接转移和间接转移,以及段间的直接转移和间接转移地址。对直接转移,其转移地址为当前指令的偏移地址(即 IP 的内容)加 上位移量或由指令中直接得出;对间接转移,转移地址等于指令中寄存器的内容或由寄存器内容所指向的 存储单元的内容。(1) 段内直接转移。转移的物理地址=(CS) l6 +2300H=02000H+2300H=04300H (2)段内间接转移。转移的物理地址= (CS) 16+ BX= (CS) l6+(217A0H)=02000H+2300H=04300H (3)段间间接转移。转移的物理地址=BX+DATA=(217E2H) l6+(217

16、E0H)=90000H+0400H=90400H3.4 试说明指令 MOV BX,5BX与指令 LEA BX,5BX的区别。前者是数据传送类指令,表示将数据段中以(BX+5)为偏移地址的 16 位数据送寄存器 BX. 后者是取偏移地址指令,执行的结果是(BX)= (BX)5,即操作数的偏移地址为(BX)+5。3.5 设堆栈指针 SP 的初值为 2300H,(AX)50ABH,(BX)=1234H。执行指令 PUSH AX 后,(SP)?,再 执行指令 PUSH BX 及 POP AX 之后,(SP)= ?(AX)= ?(BX)?堆栈指针 SP 总是指向栈顶,每执行一次 PUSH 指令 SP-2

17、,执行一次 POP 指令 SP+2.所以,执行PUSH AX 指令后,(SP)=22FEH;再执行 PUSH BX 及 POP AX 后,(SP)=22FEH,(AX)=(BX)=1234H3.6 指出下列指令的错误:(1) MOV AH,CX (2) MOV 33H,AL (3) MOV AX, SIDI (4) MOV BX,SI(5) ADD BYTE PTRBP,256 (6) MOV DATASI,ES:AX (7) JMP BYTE PTRBX (8) OUT 230H,AX(9) MOV DS,BP (10) MUL 39H (1)指令错。两操作数字长不相等(2)指令错。MOV

18、指令不允许目标操作数为立即数(3) 指令错。在间接寻址中不允许两个间址寄存器同时为变址寄存器。 (4)指令错。MUV 指令不允许两个操作数同时为存储器操作数。 (5)指令错。ADD 指令要求两操作数等字长。 (6)指令错。源操作数形式错,寄存器操作数不加段重设符。 (7)指令错。转移地址的字长至少应是 16 位的。(8)指令错。对输人输出指令,当端口地址超出 8 位二进制数的表达范围(即寻址的端口超出 256 个) 时,必须采用间接寻址。(9)指令正确。(10)指令错。MUL 指令不允许操作数为立即数。3.7 已知(AL) =7BH, (BL) =38H,试问执行指令 ADD AL, BL 后

19、,AF、CF、OF、PF、SF 和 ZF 的值各为多少?AF=1,CF=0,OF=1,PF=0,SF=l,ZF=03.8 试比较无条件转移指令、条件转移指令、调用指令和中断指令有什么异同?无条件转移指令的操作是无条件地使程序转移到指定的目标地址,并从该地址开始执行新的程序段,其转移的目标地址既可以是在当前逻辑段,也可以是在不同的逻辑段;条件转移指令是在满足一定条 件下使程序转移到指定的目标地址,其转移范围很小,在当前逻辑段的-128+127 地址范围内。调用指令是用于调用程序中常用到的功能子程序,是在程序设计中就设计好的。根据所调用过程人口地址的位置可将调用指令分为段内调用(入口地址在当前逻辑

20、段内)和段间调用。在执行调用指令后,CPU要保护断点。对段内调用是将其下一条指令的偏移地址压人堆栈,对段间调用则要保护其下一条指令的偏 移地址和段基地址,然后将子程序人口地址赋给 IP(或 CS 和 IP)中断指令是因一些突发事件而使 CPU 暂时中止它正在运行的程序,转去执行一组专门的中断服务程序,并在执行完后返回原被中止处继续执行原程序。它是随机的。在响应中断后 CPU 不仅要保护断点(即 INT指令下一条指令的段地址和偏移地址),还要将标志寄存器 FLAGS 压入堆栈保存。3.9 试判断下列程序执行后,BX 中的内容MOV CL, 3MOV BX,0B7H ROL BX,1ROR BX,

21、CL该程序段是首先将 BX 内容不带进位循环左移 1 位,再循环右移 3 位。即相当于将原 BX 内容不 带进位循环右移 2 位,故结果为:(BX)=0C02DH3.10 按下列要求写出相应的指令或程序段。(1)写出两条使 AX 内容为 0 的指令。(2)使 BL 寄存器中的高 4 位和低 4 位互换。 (3)屏蔽 CX 寄存器的 bll,b7 和 b3 位。 (4)测试 DX 中的 b0 和 b8 位是否为 1。(1)(2)(3) (4).MOV AX,0XOR AX,AX ;AX 寄存器自身相异或,可使其内容清 0MOV CL, 4ROL BL,CL ;将 BL 内容循环左移 4 位,可实

22、现其高 4 位和低 4 位 的互换AND CX,0F777H ;将 CX 寄存器中需屏蔽的位“与”0。也可用 “或”指令实现AND DX,0101H ;将需侧试的位“与”1,其余“与”0 屏蔽掉CMP DX,0101 H ;与 0101H 比较JZ ONE ;若相等则表示 b0 和 b8 位同时为 13.11 分别指出以下两个程序段的功能: (1) (2)MOV CX,l0 CLDLEA SI,FIRST LEA DI, 1200HLEA DI, SECOND MOV CX,0FOOH STD XOR AX,AXREP MOVSB REP STOSW(1)该段程序的功能是:将数据段中 FIRS

23、T 为最高地址的 10 个字节数据按减地址方向传送到附加段SECOND 为最高地址的向前 10 个单元中。(2)将附加段中偏移地址为 1200H 单元开始的 0FOOH 个字单元清 0。3.12 执行以下两条指令后,标志寄存器 FLAGS 的六个状态位各为什么状态?MOV AX,84A0H ADD AX,9460H执行 ADD 指令后,6 个状态标志位的状态分别为:在两个 16 位数进行加法运算时,对 CF、ZF、SF 和 OF 会产生影响,但对 PF 和 AF 标志位,只有其低 8 位 的运算影响它们的状态。各标志位的状态分别为:AF=0,PF=1,CF=1,ZF=0,SF=0,OF=1。3

24、.13 将+46 和-38 分别乘以 2,可应用什么指令来完成?如果除以 2 呢?因为对二进制数,每左移一位相当于乘以 2,右移一位相当于除以 2。所以,将+46 和-38 分别乘以2,可分别用逻辑左移指令(SHL)和算术左移指令(SAL) 完成。SHL 指令针对无符号数,SAL 指令针对有符号 数。当然,也可以分别用无符号数乘法指令 MUL 和有符号数乘法指令 IMUL 完成。如果是除以 2,则进行相反操作,即用逻辑右移指令 SHR 或无符号数除法指令 DIV 实现+46 除以 2 的运 算,用算术右移指令 SAR 或有符号数除法指令 IDIV 实现-38 除以 2 的运算。3.14 已知

25、AX=8060H,DX=03F8H,端口 PORT1 的地址是 48H,内容为 40H;PORT2 的地址是 84H,内容 为 85H。请指出下列指令执行后的结果。(1)OUT DX, AL (2) IN AL,PORT1 (3) OUT DX,AX (4) IN AX,48H(5) OUT PORT2,AX(1)将 60H 输出到地址为 03F8H 的端口中。(2) 从 PORT1 读入一个字节数据,执行结果:(AL)=40H。(3) 将 AX=8060H 输出到地址为 03F8H 的端口中。(4)由 48H 端口读人 16 位二进制数。(5)将 8060H 输出到地址为 84H 的端口中。

26、第 4 章 汇编语言程序设计4.1 请分别用 DB 、DW 、DD 伪指令写出在 DATA 开始的连续 8 个单元中依次存放数据 11H 、22H 、33H 、44H 、55H 、66H 、77H 、88H 的数据定义语句.DB,DW,DD 伪指令分别表示定义的数据为字节类型、字类型及双字型.其定义形式为: DATA DB 11H,22H,33H,44H,55H,66H,77H,88HDATA DW 2211H,4433H,6655H,8877H DATA DD 44332211H,88776655H4.2 若程序的数据段定义如下,写出各指令语句独立执行后的结果:DSEG SEGMENTDAT

27、A1 DB 10H,20H,30H DATA2 DW 10 DUP(?) STRING DB 123DSEG ENDS(1) MOV AL,DATA1(2) MOV BX,OFFSET DATA2 (3) LEA SI,STRINGADD DI,SI取变量 DATA1 的值. 指令执行后,(AL)=10H.变量 DATA2 的偏移地址. 指令执行后,(BX)=0003H.(3)先取变量 STRING 的偏移地址送寄存器 SI,之后送 SI 的内容与 DI 的内容相加并将结果送 DI.指令执行 后,(SI)=0017H;(DI)=(DI)+0017H.4.3 试编写求两个无符号双子长数之和的程序

28、. 两数分别在 MEM1 和 MEM2 单元中,和放在 SUM 单元.MEM1 DW 1122H,3344H MEM2 DW 5566H,7788H SUM DW 2 DUP(?)DSEG ENDS CSEG SEGMENTASSUME CS:CSEG,DS:DSEG START: MOV AX,DSEGMOV DS,AXLEA BX,MEM1LEA SI,MEM2LEA DI,SUM MOV CL,2CLCAGAIN: MOV AX,BX ADC AX,SIMOV DI,AX ADD BX,2ADD SI,2ADD DI,2LOOP AGAIN HLTCSEG ENDSEND START4.4 试编写程序,测试 AL 寄存器的第 4 位(bit4)是否为 0? 测试寄存器 AL 中某一位是否为 0,可使用 TEST 指令、AND 指令、移位指令等几种方法实现。 如:TEST AL,10HJZ NEXT. NEXT:或者: MOV CL,4SHL

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

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