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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

计算机原理与接口技术课后习题答案.docx

1、计算机原理与接口技术课后习题答案第1章 基础知识1.1 计算机中常用的计数制有哪些?解:二进制、八进制、十进制(BCD)、十六进制。1.2 请说明机器数和真值的区别。解:把符号数值化的数码称为机器数或机器码,原来的数值叫做机器数的真值。1.3 完成下列数制的转换。解:(1)166,A6H (2)0.75 (3)11111101.01B, FD.4H (4) 5B.AH, (10010001.011000100101)BCD1.4 8位和16位二进制数的原码 、补码和反码可表示的数的范围分别是多少?解:原码(-127 127)、(-32767 32767)补码 (-128 127)、(-3276

2、8 32767)反码(-127 127)、(-32767 32767)1.5 写出下列真值对应的原码和补码的形式。(1)X= -1110011B(2)X= -71D(3)X= 1001001B解:(1)原码:11110011 补码:10001101(2)原码:11000111 补码:10111001(3)原码:01001001 补码:010010011.6 写出符号数10110101B的反码和补码。 解:11001010,110010111.7 已知X和Y的真值,求X Y的补码(1)X=-1110111B Y= 1011010B(2)X=56D Y= -21D解:(1)11100011(2)0

3、01000111.8 已知X= -1101001B,Y= -1010110B,用补码求X-Y的值。解:X-Y补=11101101 X-Y=-0010011B1.9 若给字符4和9的ASCII码加奇校验,应是多少?若加偶校验?解:奇校验:4 :(00110100B)34H,9:(10111001B)B9H 偶校验:4 :(10110100B)B4H,9: (00111001B)39H1.10 若与门的输入端A、B、C的状态分别为1、0、1,则该与门的输出端状态为?若将这3个信号连接到或门,那么或门的输出又是什么状态?解:1.11 要使与非门输出“0”,则与非门输入端各位的状态应该是什么?如果使与

4、非门输出“1”,其输入端各位的状态又应该是什么? 解:全1;至少有一个01.12如果74LS138译码器的C、B、A三个输入端的状态为011,此时该译码器的8个输出端中哪一个会输出“0”? 解:#Y31.13图1-16中,Y1=?Y2=?Y3=?138译码器哪一个输出端会输出低电平?解:Y1=0; Y2=1; Y3=1;Y6第2章 微处理器和总线2.2说明8086的EU和BIU的主要功能。在执行指令期间,BIU能直接访问存储器吗? 解:执行单元EU负责执行指令。EU在工作时不断地从指令队列取出指令代码,对其译码后产生完成指令所需要的控制信息。数据在ALU中进行运算,运算结果的特征保留在标志寄存

5、器FLAGS中。总线接口单元BIU负责CPU与存储器、I/O接口之间的信息传送。BIU取出的指令被送入指令队列供EU执行,BIU取出的数据被送入相关寄存器中以便做进一步的处理。 在执行指令期间,BIU能直接访问存储器.因为EU和BIU可以并行工作,EU需要的指令可以从指令队列中获得,这时BIU预先从存储器中取出并放入指令队列的。在EU执行指令的同时,BIU可以访问存储器取下一条指令或指令执行时需要的数据。 2.3 8088CPU工作在最小模式下:(1)当CPU访问存储器时,要利用哪些信号?(2)当CPU进行I/O操作时,要利用哪些信号?(3)当HOLD有效并得到响应时,CPU的哪些信号置高阻?

6、 解:(1)要利用信号线包括#WR、#RD、IO/#M、ALE以及AD0AD7、A8A19。 (2)同(1)。(3)所有三态输出的地址信号、数据信号和控制信号均置为高阻态。 2.4 总线周期中,什么情况下要插入TW 等待周期?插入TW周期的个数,取决于什么因素? 解:在每个总线周期的T3的开始处若READY为低电平,则CPU在T3后插入一个等待周期TW。在TW的开始时刻,CPU还要检查READY状态,若仍为低电平,则再插入一个TW 。此过程一直进行到某个TW开始时,READY已经变为高电平,这时下一个时钟周期才转入T4。可以看出,插入TW周期的个数取决于READY电平维持的时间。 2.5 若8

7、088工作在单CPU方式下,在表2-5中填入不同操作时各控制信号的状态。 解:结果如下所示。 2.6 在8086/8088 CPU中,标志寄存器包含哪些标志位?各位为0(为1)分别表示什么含义? 解:(略),见书第49页。2.7 8086/8088 CPU中,有哪些通用寄存器和专用寄存器?说明它们的作用。 解:通用寄存器包含以下8个寄存器:AX、BX、CX和DX寄存器一般用于存放参与运算的数据或运算的结果。除此之外:AX:主要存放算术逻辑运算中的操作数,以及存放I/O操作的数据。 BX:存放访问内存时的基地址。CX:在循环和串操作指令中用作计数器。DX:在寄存器间接寻址的I/O指令中存放I/O

8、地址。在做双字长乘除法运算时,DX与AX合起来存放一个双字长数。 SP:存放栈顶偏移地址。BP:存放访问内存时的基地址。 SP和BP也可以存放数据,但它们的默认段寄存器都是SS。 SI:常在变址寻址方式中作为源地址指针。DI:常在变址寻址方式中作为目标地址指针。专用寄存器包括4个段寄存器和两个控制寄存器:CS:代码段寄存器,用于存放代码段的段基地址。DS:数据段寄存器,用于存放数据段的段基地址。SS:堆栈段寄存器,用于存放堆栈段的段基地址。ES:附加段寄存器,用于存放附加段的段基地址。IP:指令指针寄存器,用于存放下一条要执行指令的偏移地址。 FLAGS:标志寄存器,用于存放运算结果的特征。2

9、.8 8086/8088 系统中,存储器为什么要分段?一个段最大为多少个字节?最小为多少个字节?解:分段的主要目的是便于存储器的管理,使得可以用16位寄存器来寻址20位的内存空间。一个段最大为64KB,最小为16B。2.9 在8086/8088 CPU中,物理地址和逻辑地址是指什么?已知逻辑地址为1F00:38A0H,如何计算出其对应的物理地址?解:物理地址时CPU存取存储器所用的地址。逻辑地址是段和偏移地址形式的地址,即汇编语言程序中使用的存储器地址。 若已知逻辑地址为1F00:38A0H,则对应的物理地址=1F00H x 16 38A0H=228A0H。 2.10 若CS=8000H,则当

10、前代码段可寻址的存储空间的范围是多少?解(CS)=8000H时,当前代码段可寻址的存储空间范围为80000H8FFFFH。第3章 8088/8086指令系统3.1什么叫寻址方式?8086/8088CPU共有哪几种寻址方式?解:寻址方式主要是指获得操作数所在地址的方法. 8086/8088CPU具有:立即寻址、直接寻址、寄存器寻址、寄存器间接寻址、寄存器相对寻址、基址一变址寻址、基址一变址相对寻址以及隐含寻址等8种寻址方式。3.2设(DS)=6000H,(ES)=2000H,(SS)=1500H,(SI)=00A0H,(BX)=0800H,(BP)=1200H,字符常数VAR为0050H. 请分

11、别指出下列各条指令源操作数的寻址方式,并计算除立即寻址外的其他寻址方式下源操作数的物理地址是多少?(1) MOV AX,BX (2) MOV DL,80H(3) MOV AX, VAR (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 = 60000H00

12、A0H0800H0050H608F0H(5)立即寻址(6)寄存器间接寻址. 操作数的物理地址= (ES) 16(BX) = 20000H0800H = 20800H(7)寄存器间接寻址。 操作数的物理地址= (SS) 16(BP) = 15000H1200H= 16200H(8)寄存器相对寻址 操作数的物理地址(DS) 16(BX)20H = 60000H0800H20H= 60820H 3.3 假设(DS)= 212AH,(CS)= 0200H,(IP)= 1200H,(BX)= 0500H,位移量DATA=40H,217A0H =2300H,217E0H=0400H,217E2H =900

13、0H 试确定下列转移指令的转移地址. (1) JMP 2300H (2) JMP WORD PTRBX (3) JMP DWORD PTRBX DATA 解:转移指令分为段内转移和段间转移,根据其寻址方式的不同,又有段内的直接转移和间接转移,以及段间的直接转移和间接转移地址。对直接转移,其转移地址为当前指令的偏移地址(即IP的内容)加上位移量或由指令中直接得出;对间接转移,转移地址等于指令中寄存器的内容或由寄存器内容所指向的存储单元的内容。 (1) 段内直接转移。转移的物理地址=(CS) l6 2300H =02000H 2300H=04300H (2)段内间接转移。转移的物理地址= (CS)

14、 16 BX = (CS) l6 217A0H =02000H 2300H=04300H (3)段间间接转移。转移的物理地址=BX DATA =217E2H l6 217E0H =90000H 0400H=90400H 3.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)?,再

15、执行指令PUSH BX及POP AX之后,(SP)= ?(AX)= ?(BX)? 解:堆栈指针SP总是指向栈顶,每执行一次PUSH指令SP-2,执行一次POP指令SP 2.所以,执行PUSH AX指令后,(SP)=22FEH;再执行PUSH BX及POP AX后,(SP)=22FEH,(AX)=(BX)=1234H 3.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)

16、 OUT 230H,AX (9) MOV DS,BP (10) MUL 39H 解: (1)指令错。两操作数字长不相等 (2)指令错。MOV指令不允许目标操作数为立即数 (3) 指令错。在间接寻址中不允许两个间址寄存器同时为变址寄存器。 (4)指令错。MUV指令不允许两个操作数同时为存储器操作数。 (5)指令错。ADD指令要求两操作数等字长。 (6)指令错。源操作数形式错,寄存器操作数不加段重设符。 (7)指令错。转移地址的字长至少应是16位的。 (8)指令错。对输人输出指令,当端口地址超出8位二进制数的表达范围(即寻址的端口超出256个)时,必须采用间接寻址。 (9)指令正确。 (10)指令

17、错。MUL指令不允许操作数为立即数。 3.7 已知(AL) =7BH, (BL) =38H,试问执行指令ADD AL, BL后,AF、CF、OF、PF、SF和ZF的值各为多少? 解:AF=1,CF=0,OF=1,PF=0,SF=l,ZF=0 3.8 试比较无条件转移指令、条件转移指令、调用指令和中断指令有什么异同? 解:无条件转移指令的操作是无条件地使程序转移到指定的目标地址,并从该地址开始执行新的程序段,其转移的目标地址既可以是在当前逻辑段,也可以是在不同的逻辑段;条件转移指令是在满足一定条件下使程序转移到指定的目标地址,其转移范围很小,在当前逻辑段的-128 127地址范围内。 调用指令是

18、用于调用程序中常用到的功能子程序,是在程序设计中就设计好的。根据所调用过程人口地址的位置可将调用指令分为段内调用(入口地址在当前逻辑段内)和段间调用。在执行调用指令后,CPU要保护断点。对段内调用是将其下一条指令的偏移地址压人堆栈,对段间调用则要保护其下一条指令的偏移地址和段基地址,然后将子程序人口地址赋给IP(或CS和IP) 中断指令是因一些突发事件而使CPU暂时中止它正在运行的程序,转去执行一组专门的中断服务程序,并在执行完后返回原被中止处继续执行原程序。它是随机的。在响应中断后CPU不仅要保护断点(即INT指令下一条指令的段地址和偏移地址),还要将标志寄存器FLAGS压入堆栈保存。3.9

19、 试判断下列程序执行后,BX中的内容 MOV CL, 3 MOV BX,0B7H ROL BX,1 ROR BX,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)MOV AX,0 XOR AX,AX ;AX寄存器自身相异或,可使其内容清0(2)MOV CL, 4ROL BL,CL

20、;将BL内容循环左移4位,可实现其高4位和低4位的互换(3)AND CX,0F777H ;将CX寄存器中需屏蔽的位“与”0。也可用“或”指令实现(4)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,0FOOHSTD XOR AX,AXREP MOVSB REP STOSW解: (1)该段程序的功能是:将数

21、据段中FIRST为最高地址的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.13将 46和-38分别乘以2

22、,可应用什么指令来完成?如果除以2呢? 解:因为对二进制数,每左移一位相当于乘以2,右移一位相当于除以2。所以,将 46和-38分别乘以2,可分别用逻辑左移指令(SHL)和算术左移指令(SAL) 完成。SHL指令针对无符号数,SAL指令针对有符号数。 当然,也可以分别用无符号数乘法指令MUL和有符号数乘法指令IMUL完成。 如果是除以2,则进行相反操作,即用逻辑右移指令SHR或无符号数除法指令DIV实现 46除以2的运算,用算术右移指令SAR或有符号数除法指令IDIV实现-38除以2的运算。3.14已知AX=8060H,DX=03F8H,端口PORT1的地址是48H,内容为40H;PORT2的

23、地址是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的端口中。第4章 汇编语言程序设计4.1请分别用DB 、DW 、DD伪指令写出在DATA开始的连续8个单元中依次存放数据11H 、2

24、2H 、33H 、44H 、55H 、66H 、77H 、88H的数据定义语句. 解:DB,DW,DD伪指令分别表示定义的数据为字节类型、字类型及双字型.其定义形式为: DATA DB 11H,22H,33H,44H,55H,66H,77H,88H DATA DW 2211H,4433H,6655H,8877H DATA DD 44332211H,88776655H4.2若程序的数据段定义如下,写出各指令语句独立执行后的结果:DSEG SEGMENTDATA1 DB 10H,20H,30HDATA2 DW 10 DUP(?)STRING DB 123DSEG ENDS(1) MOV AL,DA

25、TA1(2) MOV BX,OFFSET DATA2(3) LEA SI,STRINGADD DI,SI解:(1)取变量DATA1的值. 指令执行后,(AL)=10H.(2)变量DATA2的偏移地址. 指令执行后,(BX)=0003H.(3)先取变量STRING的偏移地址送寄存器SI,之后送SI的内容与DI的内容相加并将结果送DI.指令执行后,(SI)=0017H;(DI)=(DI) 0017H.4.3 试编写求两个无符号双字长数之和的程序. 两数分别在MEM1和MEM2单元中,和放在SUM单元.解:DSEG SEGMENTMEM1 DW 1122H,3344HMEM2 DW 5566H,77

26、88HSUM DW 2 DUP(?)DSEG ENDSCSEG SEGMENT ASSUME CS:CSEG,DS:DSEGSTART: MOV AX,DSEG MOV DS,AX LEA BX,MEM1 LEA SI,MEM2 LEA DI,SUM MOV CL,2 CLCAGAIN: MOV AX,BX ADC AX,SI MOV DI,AX ADD BX,2 ADD SI,2 ADD DI,2 LOOP AGAIN HLTCSEG ENDS END START4.4试编写程序,测试AL寄存器的第4位(bit4)是否为0?解: 测试寄存器AL中某一位是否为0,可使用TEST指令、AND指令

27、、移位指令等几种方法实现。 如:TEST AL,10H JZ NEXT . . . NEXT: 或者: MOV CL,4 SHL AL,CL JNC NEXT . NEXT:4.5 试编写程序,将BUFFER中的一个8位二进制数转换为ASCII码,并按位数高低顺序存放在ANSWER开始的内存单元中。解:DSEG SEGMENTBUFFER DB ?ANSWER DB 3 DUP(?)DSEG ENDSCSEG SEGMENT ASSUME CS:CSEG,DS:DSEGSTART:MOV AX,DSEG MOV DS,AX MOV CX,3 ;最多不超过3为十进制数(255) LEA DI,

28、ANSWER ;DI指向结果存放单元 XOR AX,AX MOV AL,BUFFER ;取要转换的二进制数 MOV BL,0AH ;基数10AGAIN:DIV BL ;用除10取余的方法转换 ADD AH,30H ;十进制数转换成ASCII码 MOV DI, AH ;保存当前的结果 INC DI ;指向下一个位保存单元 AND AL,AL ;商为0?(转换结束?) JZ STO ;若结束,退出 MOV AH,0 LOOP AGAIN ;否则循环继续STO: MOV AX,4C00H INT 21H ;返回DOSCSEG ENDS END START4.6 假设数据项定义如下:DATA1 DB

29、HELLO!GOOD MORNING!DATA2 DB 20 DUP(?)用串操作指令编写程序段,使其分别完成以下功能:(1)从左到右将DATA1中的字符串传送到DATA2中。(2)传送完后,比较DATA1和DATA2中的内容是否相同。(3)把DATA1中的第3和第4个字节装入AX。(4)将AX的内容存入DATA2 5开始的字节单元中。解:(1) MOV AX,SEG DATA1 MOV DS,AX MOV AX,SEG DATA2MOV ES,AXLEA SI,DATA1LEA DI,DATA2MOV CX,20CLDREP MOVSB(2)LEA SI,DATA1LEA DI,DATA2M

30、OV CX,20CLD REPE CMPSB。(3)LEA SI,DATA1ADD SI,2LODSW(4)LEA DI,DATA2 ADD DI,5 STOSW4.7执行下列指令后,AX寄存器的内容是多少?TABLE DW 10,20,30,40,50ENTRY DW 3.MOV BX,OFFSET TABLEADD BX,ENTRYMOV AX,BX解:(AX)=1E00H4.8 编写程序段,将STRING1中的最后20个字符移到STRING2中(顺序不变)。解:首先确定STRING1中字符串的长度,因为字符串的定义要求以$符号结尾,可通过检测$符确定出字符串的长度,设串长度为COUNT,则程序如下:LEA SI,STRING1LEA DI,STRING2ADD SI,COUNT-20MOV CX,20CLDREP MOVSB4.9 假设一个48位数存放在DX:AX:BX中,试编写程序段,将该48位数乘以2.解: 可使用移位指令来实现。首先将BX内容逻辑左移

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2