(完整版)微型计算机习题答案_第1页
(完整版)微型计算机习题答案_第2页
(完整版)微型计算机习题答案_第3页
(完整版)微型计算机习题答案_第4页
(完整版)微型计算机习题答案_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

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

文档简介

1、第三章习题答案 Pentium 的指令系统习题序号不对应问答题1. 断点中断是指怎样一种中断?在程序调试中有什么作用? 断点中断指令有什么特点?设置断点过程对应了一种什么操作?这种 操作会产生什么运行结果?答: 断点中断即中断类型 3,一般该中断处理程序进行程序调试,主要功能是显示一些寄存器的值,并给出一些重要的信息。在程 序调试中,断点中断就是从一个较长的程序中分离出一个较短的存在问题的程序段。断点中断的特点是指令占一个字节。设置断点 过程对应 int 3 替换那条指令,在中断处理程序中再恢复该被替换的指令,并修改堆栈中的断点地址为中断处的地址而不是下一条 指令地址。这种操作使断点中断不会影

2、响程序的功能。2. 用普通运算指令执行 BCD码运算时,为什么要进行十进制调整?具体讲,在进行BCD码的加、减、乘、除运算时,程序段的什么位置必须加上十进制调整指令?答:在BCD码中,只允许0?/FONT>9这10个数字出现,但有时候的运算结果会超过此范围,因此要进行十进制调整。进行加、件或 乘法运算时,调整指令必须紧跟在算术指令后面,在进行除法运算时,调整指令放在除法指令之前。3. 普通移位指令(带 CF的和不带CF的两类)在执行操作时,有什么差别?在编制乘法程序时,为什么常用移位指令来代替乘除法指令?试编写一个程序段,实现将BX中的数除以10,结果仍放在BX中。答:带CF和不带CF的

3、普通移位指令的差异:前者用于算术运算,后者用于逻辑运算。程序段:MoV CL ,0AHMOV AX, BXIDIV CLMoV BX, AX4. 在使用条件转移指令时,特别要注意它们均为相对转移指令,请解释“相对转移”的含义。如果要往较远的地方进行条件转移, 那么,程序中应该怎样设置?解答 只能在从本指令为中心的 -128 到+1 27字节范围内转移的称为相对转移。如果要往较远的地方进行条件转移时,可以先用条 件转移指令转到附近一个单元,然后,从此单元起放一条无条件转移指令,再通过这条无条件转移指令转到较远的目的地址。5、带参数的返回指令用在什么场合?设栈顶地址为3000H当执行RET 000

4、6后,SP的值为多少?解答 带参数的返回指令可用在这样的情况: 主程序为某个子程序提供一定的参数或者参数地址先送到堆栈中,通过堆栈传递给子程序。当栈顶指针 SP=3000H执行RET0006时,弹出3000H和3001H处的返回地址,腾出3002H?/FONT>3007H勺空间,所以SP=3008H6、用循环控制指令设计程序段,从60H个元素中寻找一个最大值,结果放在AL中答案 MoV SI, oFFSET DATA1 ; 将数据起始地址送 SIMoV CX, 5FH ; 有 60H-1 次循环MOV AL, SI;将第一个元素放 AL中CoMPARE: INC SICMP AL, SI

5、JL XCHMAXJMP NEXTXCHMAX: MOV AL, SINEXT: LOOP COMPARE7、中断指令执行时,堆栈的内容有什么变化?中断处理子程序的人口地址是怎样得到的?答案中断指令执行时,堆栈内容变化如下:标志寄存器被推入堆栈,且SP减2 ,然后CPU将主程序的下一条指令地址即断点地址的段值和偏移量推入堆栈,且 SP减4。某中断处理子程序的入口地址即中断向量,由该中断类型号的 4倍为内存地址,在该地址处的 4个字节内容即该中断向量。8、中断返回指令IRET和普通子程序返回指令 RET在执行时,具体操作内容什么不同?答案IRET须弹出堆栈中标志寄存器的值,而RET则不需要。9、

6、断点中断是指怎样一种中断?在程序调试中有什么作用?断点中断指令有什么特点?设置断点过程对应了一种什么操作?这种操作会产生什么运行结果?答案 断点中断即中断类型 3,一般该中断处理程序进行程序调试,主要功能是显示一些寄存器的值,并给出一些重要的信息。 在程序调试中,断点中断就是从一个较长的程序中分离出一个较短的存在问题的程序段。断点中断的特点是指令占一个字节。设置断点过程对应 int 3 替换那条指令,在中断处理程序中再恢复该被替换的指令,并修改堆栈中的断点地址为中断处的地址而不 是下一条指令地址。这种操作使断点中断不会影响程序的功能。10、HLT 指令用在什么场合?如 CPU 在执行 HLT

7、指令时遇到硬件中断并返回后,以下应执行哪条指令?答案HLT用在使CPU处于暂停状态而等待硬件中断的场合。在执行HLT指令遇到硬件中断并返回后将执行HLT后面的一条指令。11、总线封锁指令用在什么场合? 以飞机定票系统为例说明总线封锁指令的作用(设飞机定票系统为一个多处理器系统,每个处 理器都是平等的)。答案 总线封锁指令用在多个处理器争用同一资源或设备的场合。在飞机票系统中,当一个处理器受理业务时,便用LoCK封锁总线,使其它处理器不能访问总线,避免引起冲突。11、设当前SS=2010H SP=FEooH BX=3457H计算当前栈顶的地址为多少?当执行PUSHBX指令后,栈顶地址和栈顶 2个

8、字节的内容分别是什么?答案当前栈顶的地址 2010H*16+FE00H=2FF00H执行PUSH BX指令后,堆栈地址指针 SP减2 ,则栈顶地址为 2FEEDH栈顶2个 字节的内容为 57H、34H。用串操作指令设计实现以下功能的程序段:首先将100H个数从2170H处搬到1000H处,然后,从中检索相等于 AL中字符的单元,并将此单元值换成空格符解答 BUFF1 EQU, 1000HBUFF2 EQU, 2170HSTART: MOV SI, OFFSET BUFF2LEA DI, BUFF1MOV CX, 100HCYCLE: MOV AL, SIMOV DI , ALINC SIINC

9、 DILOOP CYCLEANOTHE:RMOV DI, OFFSET BUFF1MOV CX, 100CLDAGE: SCASBDEC CXJZ FINJNZ AGEJMP OVERFIN: MOV DI , 20HCMP CX, 0JNZ AGEOVER: RET13、用乘法指令时,特别要注意先判断用有符号数乘法指令还是用无符号数乘法指令,这是为什么? 解答 用乘法指令时,特别要注意先判断用有符号数乘法指令还是用无符号数乘法指令,是因为在执行乘法运算时,要想使无符号 数相乘得到正确的结果,有符号数相乘时,就得不到正确的结果;要想使有符号数相乘得到正确的结果,无符号数相乘时,就得不 到正确的

10、结果。13、 字节扩展指令和字扩展指令用在什么场合?举例说明解答遇到两个字节相除时,要预先执行CBW旨令,以便产生一个双倍长度的被除数。否则就不能正确的执行除法操作。CW国理例如: CBW MOV AL, a; CWD MOV AX, X;MOV CL , b; MOV CX, Y;CBW AL; CWD AX;DIV AX, CL; DIV AX, CX;14、什么叫BCD码?什么叫组合的 BCD码?什么叫非组合的 BCD码? 8086汇编语言在对BCD码进行加、减、乘、除运算时,采用 什么方法?解答在计算机中,可用4位二进制码表示一个十进制码,这种代码叫BCD码;用一个字节表示 2位BCD

11、码就是组合BCD码;一个字节只用低4位表示BCD码,高四位为0的为非组合BCD码。计算机对BCD码进行加、减、乘、除运算,通常采用两种办法:一种是在指令系统中设置一套转专用于BCD码的指令;另一种方法是利用对普通二进制数的运算指令算出结果,然后用专门的指令对结果进行调整,或者反过来,先对数据进行调整,再用二进制 数指令进行运算。15、用普通运算指令执行 BCD码运算时,为什么要进行十进制调整?具体讲 ,在进行BCD码的加、减、乘、除运算时,程序段的什 么位置必须加上十进制调整指令?解答在BCD码中,只允许0?/FONT>9这10个数字出现,但有时候的运算结果会超过此范围,因此要进行十进制

12、调整。进行加、 件或乘法运算时,调整指令必须紧跟在算术指令后面,在进行除法运算时,调整指令放在除法指令之前。16、普通移位指令(带 CF的和不带CF的两类)在执行操作时,有什么差别?在编制乘法程序时,为什么常用移位指令来代替乘除 法指令?试编写一个程序段,实现将BX中的数除以10,结果仍放在BX中。解答带CF和不带CF的普通移位指令的差异:前者用于算术运算,后者用于逻辑运算。程序段:MOV CL, 0AHMOV AX, BXIDIV CLMOV BX, AX程序改错及编程1.下面的程序段将 ASCIl码的空格字符填满100个字节的字符表。阅读这一程序,画出流程,并说明使用CLD指令和REP S

13、ToSB旨令的作用,再指出REP STOSBl令执行时和那几个寄存器的设置有关?MOVCX, SEG TABLE; TABLE为字节表表头MOVES, CXMOVDI, OFFSET TABLE; DI指向字节表MOVAL, ' 'MOVCX, 64H;字节数CALLFILLM;调用数子程序FILLM: JCXZ EXIT;CX为0则退出PUSH DI保存寄存器PUSH CXCLDREP STOSB方向标志清零POP CX1重复填数PoP DIEXIT: RET答:CLD指令作用:方向标志清 0; REPSTOSB旨令作用:重复CX次将AL中的字节填入ES:DI为起始的表内,D

14、I增量、减量根据DF确定:DF=O, DI每次增量;DF=1, DI每次减量。STOSB旨令执时,与 AX ES DI寄存器和Flag的DF位设置有关。流程图如下:2.下程序将一个存储块的内容复制到另一个存储快,进入存储段时,SI中为源区起始地址的偏移量,DI中为目的区起始地址的偏移量,CX中为复制的字节数。阅读程序并说明具体的REP MOCS指令使用与那些寄存器有关?PUSHDI;保存寄存器PUSHSIPUSHCXCMPDI, SI ;看源区和目的区的地址哪个高JBELOWER ;如目的区地址底,则转移STD如目的区地址高,则设方向标志为ADDSI, CX ;从最后一个字节开始复制DECSI

15、;调整源区地址ADDDI, CXDECDI;调整目的区地址JMPMOVEMLOWER: CLD;从第一个字节开始复制MOVEM: REP MOVSBPOP CXNOTCXNOTDXADDAX, 1ADCBX, 0ADCCX, 0ADCDX, 0POP SIPOP DIRET答:REP MoVSB的作用是重复 CX次将DS:SI中字节传送到ES:DI中。SI、DI 加或减 1 由 DF确定,DF=O,力口。REP使 CX减 1 ,到0后结束传送。所以 REP MOVSB指令与CX SI、DI、ESDS寄存器和FIag的DF位设置有关。3. 下面的程序实现两个32 位带符号数的乘法,其中调用了题3

16、.33中的非符号数相乘的程序 MUL64结果放在DX CX BX AX四个寄存器中, 进入程序时,DXAX中为被乘数,CX BX中为乘数。读懂程序后再设计一个 16位带符号数和32位带符号数相乘程序。MULS64: MOV 1000, 0; 1000单元作为负数标志CMP DX, 0;乘数为负数吗 ?JNS CHKK;否,则转 CHKKNOT AX;是, 则取补码NOT DXADD AX, 1ADC DX, 0NOT 1000;负数标志置 1CHKK: CMP CX, 0;乘数为负数吗 ?JNS GOMUL;否, 则转 GOMULNOT BX;是, 则取补码NOT CXADD BX, 1ADC CX, 0NOT 1000;将负数标志取反JGONUL: CALL MUL64;调用非符号数乘法程序CMP 1000, 0;结果为正数吗?JZ EXIIT;是正数,则转移NOT AX;是负数,则取补码NOTBXEXIIT: RETMULS48: MOV 1000, 0答:(DX、AX)*CX->DX CX AX,为有符号数 单元作为负数标志CMP DX, 0乘数为负数吗 ?JNS CHKKNOT AX否,则转 CHKK 是 , 则取补码NOT DXADD

温馨提示

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

评论

0/150

提交评论