《微机原理》复习思考题第3章 8086的寻址方式和指令系统3.1 8086汇编语言指令的寻址方式有哪几类?用哪一种寻址方式的指令执行速度最快?3.2 直接寻址方式中,一般只指出操作数的偏移地址,那么,段地址如何确定?如果要用某个段寄存器指出段地址,指令中应如何表示?3.3 在寄存器间接寻址方式中,如果指令中没有具体指明段寄存器,那么,段地址如何确定?3.4 用寄存器间接寻址方式时,BX,BP,SI,DI分别针对什么情况来使用?这四个寄存器组合间接寻址时,地址是怎样计算的?举例进行说明。
3.5 设DS=2100H,SS=5200H,BX=1400H,BP=6200H,说明下面两条指令所进行的具体操作:MOV BYTE PTR [BP], 2000MOV WORD PTR [BX], 20003.6 使用堆栈操作指令时要注意什么问题?传送指令和交换指令在涉及内容操作数时分别要注意什么问题?3.7 下面这些指令中哪些是正确的?哪些是错误的?如果是错误的,请说明原因。
XCHG CS, AXMOV [BX], [1000]XCHG BX, IPPUSH CSPOP CSIN BX, DXMOV BYTE[BX], 1000MOV CS, [1000]3.8 8086系统中,当对SS和SP寄存器的值进行修改时,有什么特殊规定?这样做的原因是什么?[解答] 凡是遇到给SS寄存器赋值的传送指令时,系统会自动禁止外部中断,等到本条指令和下条指令执行之后,又自动恢复对SS寄存器赋值前的中断开放情况。
这样做是为了允许程序员连续用两条指令分别对SS和SP寄存器赋值,同时又防止堆栈空间变动过程中出现中断。
3.9 以下是格雷码的编码表0——0000 1——0001 2——0011 3——0010 4——01105——0111 6——0101 7——0100 8——1100 9——1101请用换码指令和其他指令设计一个程序段,实现格雷码往ASCII的转换。
3.10 用加法指令设计一个简单程序,实现两个16位十进制数的加法,结果放在被加数单元。
3.11 为什么用增量指令或减量指令设计程序时,在这类指令后面不用进位标志CF作为判断依据?3.12 用乘法指令时,特别要注意先判断用有符号数乘法指令还是用无符号数乘法指令,这是为什么?3.13 字节扩展指令和字扩展指令用在什么场合?举例说明。
[解答] 遇到两个字节相除时,要预先执行CBW指令,以便产生一个双倍长度的被除数。
否则就不能正确的执行除法操作。
CWD同理。
例如:CBW MOV AL ,a; CWD MOV AX, X;MOV CL , b; MOV CX, Y;CBW AL; CWD AX;DIV AX, CL; DIV AX, CX;3.14 什么叫BCD码?什么叫组合的BCD码?什么叫非组合的BCD码?8086 汇编语言在对BCD码进行加、减、乘、除运算时,采用什么方法?[解答] 在计算机中,可用4位二进制码表示一个十进制码,这种代码叫BCD码;用一个字节表示2位BCD码就是BCD码;计算机对BCD码进行加、减、乘、除运算,通常采用两种办法:一种是在指令系统中设置一套转专用于BCD码的指令;另一种方法是利用对普通二进制数的运算指令算出结果,然后用专门的指令对结果进行调整,或者反过来,先对数据进行调整,再用二进制数指令进行运算。
(以上7题由陈军解答)3.15 用普通运算指令执行BCD码运算时,为什么要进行十进制调整?具体讲,在进行BCD码的加、减、乘、除运算时,程序段的什么位置必须加上十进制调整指令?[解答] 在BCD码中,只允许0?/FONT>9这10个数字出现,但有时候的运算结果会超过此范围,因此要进行十进制调整。
进行加、件或乘法运算时,调整指令必须紧跟在算术指令后面,在进行除法运算时,调整指令放在除法指令之前。
3.16 普通移位指令(带CF的和不带CF的两类)在执行操作时,有什么差别?在编制乘法程序时,为什么常用移位指令来代替乘除法指令?试编写一个程序段,实现将BX中的数除以10,结果仍放在BX中。
3.17串操作指令使用时特别要注意和SI,DI这两个寄存器及方向标志DF密切相关。
请具体就指令MOVSB/MOVSW、CMPSB/CMPSW、SCASB/SCASW、LODSB/LODSW、STOSB/STOSW列表说明和SI、DI及DF 的关系。
[解答]3.18 用串操作指令设计实现以下功能的程序段:首先将100H个数从2170H处搬到1000H处,然后,从中检索相等于AL中字符的单元,并将此单元值换成空格符。
[解答] BUFF1 EQU,1000HBUFF2 EQU,2170HSTART: MOV SI,OFFSET BUFF2LEA DI,BUFF1MOV CX,100HCYCLE: MOV AL,[SI]MOV [DI],ALINC SIINC DILOOP CYCLEANOTHER:MOV DI,OFFSET BUFF1MOV CX,100CLDAGE: SCASBDEC CXJZ FINJNZ AGEJMP OVERFIN: MOV [DI],20HCMP CX,0JNZ AGEOVER: RET3.19 在使用条件转移指令时,特别要注意它们均为相对转移指令,请解释“相对转移”的含义。
如果要往较远的地方进行条件转移,那么,程序中应该怎样设置?[解答] 只能在从本指令为中心的-128到+127字节范围内转移的称为相对转移。
如果要往较远的地方进行条件转移时,可以先用条件转移指令转到附近一个单元,然后,从此单元起放一条无条件转移指令,再通过这条无条件转移指令转到较远的目的地址。
3.20 带参数的返回指令用在什么场合?设栈顶地址为3000H,当执行RET 0006 后,SP的值为多少?[解答] 带参数的返回指令可用在这样的情况:主程序为某个子程序提供一定的参数或者参数地址先送到堆栈中,通过堆栈传递给子程序。
当栈顶指针SP=3000H,执行RET 0006时,弹出3000H和3001H处的返回地址,腾出3002H?/FONT>3007H的空间,所以SP=3008H。
(以上6题由张丽解答)3.21 用循环控制指令设计程序段,从60H 个元素中寻找一个最大值,结果放在AL中。
[答案] MOV SI, OFFSET DATA1 ; 将数据起始地址送SIMOV CX, 5FH ; 有60H-1次循环MOV AL, [SI] ; 将第一个元素放AL中COMPARE: INC SICMP AL, [SI]JL XCHMAXJMP NEXTXCHMAX: MOV AL, [SI]NEXT: LOOP COMPARE3.22 中断指令执行时,堆栈的内容有什么变化?中断处理子程序的人口地址是怎样得到的? [答案] 中断指令执行时,堆栈内容变化如下:标志寄存器被推入堆栈,且SP减2,然后CPU 将主程序的下一条指令地址即断点地址的段值和偏移量推入堆栈,且SP减4。
某中断处理子程序的入口地址即中断向量,由该中断类型号的4倍为内存地址,在该地址处的4个字节内容即该中断向量。
3.23 中断返回指令IRET和普通子程序返回指令RET 在执行时,具体操作内容什么不同?[答案] IRET须弹出堆栈中标志寄存器的值,而RET则不需要。
3.25 HLT指令用在什么场合?如CPU 在执行HLT 指令时遇到硬件中断并返回后,以下应执行哪条指令?[答案] HLT用在使CPU处于暂停状态而等待硬件中断的场合。
在执行HLT指令遇到硬件中断并返回后将执行HLT后面的一条指令。
3.27 设当前SS=2010H,SP=FE00H,BX=3457H,计算当前栈顶的地址为多少?当执行PUSH BX 指令后,栈顶地址和栈顶2个字节的内容分别是什么?[答案] 当前栈顶的地址 2010H*16+FE00H=2FF00H;执行PUSH BX指令后,堆栈地址指针SP 减2,则栈顶地址为2FEEDH;栈顶2个字节的内容为57H、34H。
3.28 在DS段中有一个从TABLE开始的由160个字符组成的链表,设计一个程序,实现对此表进行搜索,找到第一个非0元素后,将此单元和下一单元清0。
( 以上由王龙输入 )[答案] MOV CX, SEG TABLEMOV DS, CX ;将段地址送DSMOV SI, OFFSET TABLE ;表偏移量送SIMOV CX, 160 ;字节数XOR AL, ALNEXT: CMP AL, [SI]JNE EXIT1INC SILOOP NEXTEXIT1: MOV [SI], ALINC SIMOV [SI], AL3.29 下面的程序段将ASCII码的空格字符填满100个字节的字符表。
阅读这一程序,画出流程,并说明使用CLD指令和REP STOSB指令的作用,再指出REP STOSB指令执行时和那几个寄存器的设置有关?MOV CX, SEG TABLE ; TABLE为字节表表头MOV ES, CXMOV DI, OFFSET TABLE ; DI指向字节表MOV AL, ' 'MOV CX, 64H ; 字节数CALL FILLM ; 调用数子程序......FILLM: JCXZ EXIT ; CX为0则退出PUSH DI ; 保存寄存器PUSH CXCLDREP STOSB ; 方向标志清零POP CX ; 重复填数POP DIEXIT: RET[答案]CLD指令作用:方向标志清0;REP STOSB指令作用:重复CX次将AL中的字节填入[ES:DI]为起始的表内,DI增量、减量根据DF确定:DF=0,DI每次增量;DF=1,DI每次减量。
STOSB 指令执时,与AX、ES、DI寄存器和Flag的DF位设置有关。
流程图:3.30 下程序将一个存储块的内容复制到另一个存储快,进入存储段时,SI中为源区起始地址的偏移量,DI中为目的区起始地址的偏移量,CX中为复制的字节数。
阅读程序并说明具体的REP MOCSB指令使用与那些寄存器有关?PUSH DI ; 保存寄存器PUSH SIPUSH CXCMP DI, SI ; 看源区和目的区的地址哪个高JBE LOWER ; 如目的区地址底,则转移STD ; 如目的区地址高,则设方向标志为1ADD SI, CX ; 从最后一个字节开始复制DEC SI ; 调整源区地址ADD DI, CXDEC DI ; 调整目的区地址JMP MOVEMLOWER: CLD ; 从第一个字节开始复制MOVEM: REP MOVSBPOP CXPOP SIPOP DIRET[答案] REP MOVSB 的作用是重复CX次将[DS:SI]中字节传送到[ES:DI]中。