[键入文字] [键入文字] [键入文字]
式。在这种工作方式下,CPU每执行完一条指令就自动地产生一次类型为1的内部中断,可以借此检查这条指令的执行情况。
例1:1278H+3469H
答:CF=0 AF=1 ZF=0 SF=0 OF=0 PF=1 例2:54E3H-27A0H
答:CF=0 AF=0 ZF=0 SF=0 OF=0 PF=0 例3:3881H+3597H
答:CF=0 AF=0 ZF=0 SF=0 OF=0 PF=1 例4:01E3H-01E3H
答:CF=0 AF=0 ZF=1 SF=0
7. 什么是堆栈?它有什么用途?堆栈指针的作用是什么?举例说明堆栈的操作。
答:堆栈是一个按照后进先出(LIFO)的原则存取数据的存储区域。堆栈的作用是为了在调用子程序(或转向中断服务程序)时,把断点及有关的寄存器、标志位及时正确地保存下来,并保证逐次正确返回。利用堆栈指针SP可以实现对栈区的自动管理。
例如:要把AX寄存器中的内容压入堆栈,用入栈指令PUSH AX(设SP原值为1000H),其操作过程如下所示:
第一步:先把SP-l→SP,然后把AH(高位字节)送入SP所指单元(即SP=1FFFH); 第二步:再次使SP-1→SP,把AL(低位字节)送至SP所指单元(此时SP=1FFEH);
数据出栈操作与入栈过程正相反:弹出时,先把AL内容弹出,然后修改SP+1→SP;再把AH内容弹出,再修改SP+1→SP。
8. 对于由8086/8088 CPU组成的系统,堆栈的位置如何确立?堆栈的首址(即SS中的值)是不是栈底?为什么?
答:8086/8088系统中堆栈的位置由SS和SP初始化后确立:其中(SS)*16决定了堆栈段起始单元的地址,即堆栈段首址;(SS)*16+(SP初值)决定了堆栈段最后一个单元的地址,即栈底;(SS)*16+(SP现值)决定了堆栈段当前可用单元的地址,即栈顶。
显然,堆栈首址并不是栈低。一般来说,在堆栈所在的内存区内,栈底为高地址端。堆栈初始化后,未压入数据时,栈底与栈顶是重合的。当堆栈压入数据后,栈顶地址总是小于栈底地址,位于低地址端。
9. Intel 8086与8088有何区别?
答:8086与8088的区别主要表现在以下几个方面:
第一、8086的指令队列可以容纳6个字节,每个总线周期在存储器中取出2个字节指令代码填入队列。而8088只能容纳4个字节,且每个总线周期只能取出1个字节指令代码。
第二、8086外部数据总线宽度为16位,8088外部数据总线宽度只有8位。注意:8086和8088外部数据总线的宽度不同将导致扩展主存储器及输入/输出接口时系统地址线和数据线连接方式的不同。
第三、其他不同的引脚定义:(1)AD15~AD0,在8086中为地址/数据复用,而在8088中AD15~AD8改为A15~A8只作地址线用;(2)34、28号引脚定义不同。
10. 试指出下列运算后的各个状态标志,并说明进位标志和溢出标志的区别:
其中,进位标志CF用于判别无符号数运算是否超出数的表示范围,而溢出标志OF用于判别带符号数运算是否超出数的表示范围。
奇偶标志PF只能判断结果低8位中“1”的个数为奇数还是偶数。
11. 什么是逻辑地址?什么是物理地址?它们之间有什么联系?各用在何处?
OF=0 PF=1
11
[键入文字] [键入文字] [键入文字]
答:逻辑地址由两个16位的部分即段基址和偏移量组成,一般在程序中出现的地址都表示为逻辑地址形式;物理地址是一个20位的地址,它是唯一能代表存储空间每个字节单元的地址,一般只出现在地址总线上。
由于8086/8088CPU中的寄存器只有16位长,所以程序不能直接存放20位的物理地址,而必须借助逻辑地址,即用两个16位的寄存器来表示物理地址。他们之间的关系是:物理地址=段基址*16+偏移量;另外,一个物理地址可对应多个逻辑地址。
12. 什么是段基值?什么是位移量?它们之间有何联系?
答:段基址即段起始地址,它的高16位地址存放在段寄存器中,称之为段基值(低4位一般为0)。存储器单元所在的位置距离段起始地址的偏移量称之为位移量。程序中一个存储单元的实际地址(即物理地址)是由这两部分共同表示的。
13. 若CS为0A000H,试说明现行代码段可寻址物理空间的范围。
答: 因为8086系统中可寻址的最大逻辑段长度为64K,所以当CS为0A000H,即段基址为CS*16=0A0000H时,现行代码段可寻址物理空间的范围为:0A0000H ~ 0AFFFFH。
14. 设现行数据段位于存储器0B0000H~0BFFFFH单元,DS段寄存器内容为多少?
答: DS段寄存器内容为0B000H。
15. 8086/8088 CPU使用的存储器为什么要分段?怎么分段?
答:在8086/8088CPU中,ALU的运算是16位的,有关的地址寄存器如SP、IP以及BP、SI、DI等都是16位的,因而对地址的运算也只能是16位。也就是说对8086/8088而言,各种寻址方式下寻找操作数的范围被限制在64KB以内。而8086/8088有20条地址线,它的直接寻址能力为1MB。这就产生了一个矛盾,即16位的地址寄存器如何去寻址20位的存储器物理地址。解决这个问题是靠存储器分段实现的:将整个1MB的内存储器以64KB为单位分为若干段。寻址一个具体物理地址时,必须要由一个段地址(基地址)左移4位(即乘16)再加上由SP(或IP、BP、SI、DI)等寄存器之值表示的、可由CPU处理的16位偏移量来形成实际的20位物理地址;其中段地址(或基地址)是由8086/8088中的段寄存器形成的。
12
[键入文字] [键入文字] [键入文字]
第3章 汇编语言
一.填空题
1.指令MOV [BX+SI],AL中的目的操作数使用______段寄存器,属于______寻址方式。
解答:指令MOV [BX+SI],AL中的目的操作数使用___DS___段寄存器,属于__基址变址____寻址方式。
2. 指令MOV BX,NUM[SI]的源操作数使用的是______寻址方式,SUB AX,[BX+SI]使用的是______寻址方式。
解答:指令MOV BX,NUM[SI]源操作数使用了变址寄存器和一个位移量,因此是变址寻址方式。 指令SUB AX,[BX+SI]中源操作数指定的一个基址寄存器BX和一变址寄存器SI,因此属于基址变址寻址方式。
3.指令LEA BX,[BP+SI]的源操作数位于 ,执行后BX的内容是 。
解答:指令LEA BX,[BP+SI]的源操作数位于 堆栈段 ,执行后BX的内容是 BP和SI的内容之和 。
4. 堆栈指针SP的初值为2000H,AX=3000H,BX=5000H,CX=1000H,问
(1)执行PUSH AX,PUSH BX后,SP= 。 (2)再执行PUSH CX,POPBX,POPAX后, SP= AX= ,BX= 解答:(1)执行PUSH AX
SP-2=1FFEH→SP,指针在位置1处,栈顶为AX的内容 执行PUSH BX
SP-2=1FFCH→SP,指针在位置2处,栈顶为BX的内容 (2)再执行PUSH CX,POPBX,POPAX后, 执行PUSH CX
SP-2=1FFAH→SP,指针在位置3处,栈顶为CX的内容 执行POP BX
将栈顶内容1000H弹出到BX中,SP+2=1FFCH→SP,指针在位置4
③1FFAH ②1FFCH④
??
00H 10H 00H
BX AX 处,BX=1000H 50H
执行POP AX ①1FFEH⑤ 00H 将栈顶内容5000H弹出到AX中,SP+2=1FFEH→SP,指针在位置5处,AX=5000H
本题的正确答案为:
(1)执行PUSH AX,PUSH BX后,SP= 1FFCH 。
(2)再执行PUSH CX,POPBX,POPAX后,
SP= 1FFEH AX= 5000H ,BX= 1000H
5.若(AX)=7531H,(BX)=42DAH,则下列指令段
SAHF
PUSH BX POPF
指令执行完毕后(AX)= ,(SF,ZF,CF,OF)=( , , , )。 解答:指令执行完毕后(AX)= 7531H ,(SF,ZF,CF,OF)=( 1 , 1 , 0 , 0 )
6. 已知AL=2EH,BL=6CH,执行指令ADD AL,BL之后,AL= ,BL= ,ZF= AF= OF= PF= CF= 。
解答:已知AL=2EH,BL=6CH,执行指令ADD AL,BL之后,AL= 9AH ,BL= 6CH ,ZF= 0 AF= 1 OF= 1 PF= 1 CF= 0 。
2000H
30H ??
13
[键入文字]
[键入文字] [键入文字]
7. 对两个无符号8位二进制数进行加法运算后,结果为0EH,且标志位CF=1,OF=1,SF=0,其结果应为十进制数 。
解答: CPU对两个无符号8位二进制数进行加法运算后,结果为0EH,且标志位CF=1,OF=1,SF=0,其结果应为十进制数 270 。
8. 设(AL)=10100000B,则执行NEG AL后,(AL)= , 设(AL)=10000000B,则执行NEG AL后,(AL)= 。
解答:基址变址寻址在计算机中的减法运算可以将减数求补,
(AL)=10100000B是一个负数,求它的真值,就对其求补 (AL)=10100000B=-1100000B=-60H
执行NEG AL后,(AL)= 01100000B=60H
9.已知:(AL)=7AH,题(1),(2)相互独立,求AL的值。
(1)SUB AL,20H (AL)=( ) (2)CMP AL,20H (AL)=( ) 解答: (1)SUB AL,20H
这条是减法指令,7AH-20H=5AH,将结果回送到AL中 因此(AL)=5AH (2)CMP AL,20H
这是比较指令,将目的操作数与源操作数相减,但不送回结果,只根据结果置标志位,即(DST) -(SRC)。指令执行后,两个操作数均不发生变化。因此(AL)=7AH
10.设DS=1000H、ES=2000H、SS=3000H、SI=00C0H、DI=0170H、BX=01B0H、AX=5657H,(10370H)=3AH,(10371H)=67H数据段中的变量NUM的偏移地址值为0050H。
①求下条指令源操作数的物理地址为 ADD AX ,NUM[BX][DI]
②指令执行完成后OF= ,CF=
解答:①ADD AX ,NUM[BX][DI]的源操作数是相对的基址变址寻址,处于数据段中,有效地址为: EA=0050H+01B0H+0170H=0370H PA=DS×10H+EA=10370H
源操作数为10370H单元和10371H单元的内容=673AH
②指令执行完成后,AX=673AH+5657H=0BD91H,OF=1(有溢出),CF=0(无进位)
11. 将DL中的内容循环右移,已知移位前CL=9,要使其移位前后内容保持不变,应选用的指令是 。
解答:将DL中的内容循环右移,已知移位前CL=9,要使其移位前后内容保持不变,应选用的指令是 RCL或RCR 。
12.串操作指令的两个隐含的指针寄存器是 。
解答:串操作指令的两个隐含的指针寄存器是 SI和DI寄存器 。
13. 指令REP MOVSB重复执行的条件为 。
解答:指令REP MOVSB重复执行的条件为 CX≠0 。
14. 串操作指令在内存中可以实现信息串的搬家,如果DS=ES且SI>DI,不能引起信息串的覆盖,应设置 。
14
[键入文字] [键入文字] [键入文字]
解答:串操作指令在内存中可以实现信息串的搬家,如果DS=ES且SI>DI,不能引起信息串的覆盖,应设置 DF=0 。
15. 将下列程序补充完整:程序的功能是在数据段ADDR1地址处有200个字节,要传送到数据段地址ADDR2处。
MOV AX,SEG ADDR1 MOV DS,AX MOV ES, MOV SI, MOV DI,OFFSET ADDR2 MOV ,200 CLD REP
解答:在存储器中实现信息块的搬家,使用重复前缀,必须先给CX赋值重复的次数。如果信息块的长度是多少个字节,用MOVSB传送时,则将此字节数赋给CX作重复次数;若用MOVSW传送时,则将此字节数÷2赋给CX作重复次数。程序要求200个字节搬移,指令中使用的重复次数为200,由此使用REP MOVSB指令,完整的程序如下:
MOV AX,SEG ADDR1 MOV DS,AX MOV ES, AX MOV SI, OFFSET ADDR1 MOV DI,OFFSET ADDR2 MOV CX ,200 CLD
REP MOVSB
16. 若指令JMP ADDR1的机器码为E93512H,此指令的CS=1500H,IP=2400H,则目标ADDR1与本指令之间的位移量为 ,执行本指令时,IP的当前值为 ,本指令执行后,CPU转移至CS:IP为 。
解答: JMP指令是无条件转移指令,JMP ADDR1的机器码为E93512H,这是三字节指令,E9H表示操作码,8086系统中,高地址存放的是高字节,低地址则是低字节,因此1235H是操作数,表示本指令与ADDR1之间的位移量为1235H。
该指令是三字节指令,执行指令时,当前IP=2400H+3=2403H。由目标偏移地址=当前IP值+指令中的位移量=2403H+1235H=3638H。因此,执行该指令后,CPU转移至1500H:3638H处。
本题的正确答案为:若指令JMP ADDR1的机器码为E93512H,此指令的CS=1500H,IP=2400H,则目标ADDR1与本指令之间的位移量为 1235H ,执行本指令时,IP的当前值为 2403H ,本指令执行后,CPU转移至CS:IP为 1500H:3638H 。
17. 阅读程序并补充完整:以TAB为首地址的100个ASCII码字符添加奇偶校验位(bit7),使每个字节中的“1”的个数为偶数,再顺序输出到10H号端口。
MOV SI,OFFSET TAB MOV CX, ① L2: MOV AL,[SI]
AND AL, ② ③ L1
15