3.6 指出下列指令的错误:
(1) MOV AH,CX (2) MOV 33H,AL (3) MOV AX, [SI][DI] (4) MOV [BX],[SI]
(5) ADD BYTE PTR[BP],256 (6) MOV DATA[SI],ES:AX (7) JMP BYTE PTR[BX] (8) 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)指令错。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地址范围内。
调用指令是用于调用程序中常用到的功能子程序,是在程序设计中就设计好的。根据所调用过程人口地址的位置可将调用指令分为段内调用(入口地址在当前逻辑段内)和段间调用。在执行调用指令后,CPU 要保护断点。对段内调用是将其下一条指令的偏移地址压人堆栈,对段间调用则要保护其下一条指令的偏移地址和段基地址,然后将子程序人口地址赋给IP(或CS和IP).
中断指令是因一些突发事件而使CPU暂时中止它正在运行的程序,转去执行一组专门的中断服务程序,并在执行完后返回原被中止处继续执行原程序。它是随机的。在响应中断后CPU不仅要保护断点(即INT指令下一条指令的段地址和偏移地址),还要将标志寄存器FLAGS压入堆栈保存。 3.9 试判断下列程序执行后,BX中的内容. MOV CL, 3 MOV BX,0B7H ROL BX,1 ROR BX,CL
解:该程序段是首先将BX内容不带进位循环左移1位,再循环右移3位。即相当于将原BX内容不带进位循环右移2位,故结果为:(BX)=0C02DH 3.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, 4
ROL BL,CL ;将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位同时为1 . .
3.11 分别指出以下两个程序段的功能: (1) (2)
MOV CX,l0 CLD
LEA SI,FIRST LEA DI, [1200H] LEA DI, SECOND MOV CX,0FOOH STD XOR AX,AX
REP MOVSB REP STOSW 解:
(1)该段程序的功能是:将数据段中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,可应用什么指令来完成?如果除以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的地址是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 、22H 、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,88776655H
4.2若程序的数据段定义如下,写出各指令语句独立执行后的结果: DSEG SEGMENT
DATA1 DB 10H,20H,30H DATA2 DW 10 DUP(?) STRING DB ‘123’ DSEG ENDS
(1) MOV AL,DATA1
(2) MOV BX,OFFSET DATA2 (3) LEA SI,STRING ADD DI,SI 解:
取变量DATA1的值. 指令执行后,(AL)=10H.
变量DATA2的偏移地址. 指令执行后,(BX)=0003H.
(3)先取变量STRING的偏移地址送寄存器SI,之后送SI的内容与DI的内容相加并将结果送DI.指令执行后,(SI)=0017H;(DI)=(DI)+0017H.
4.3 试编写求两个无符号双子长数之和的程序. 两数分别在MEM1和MEM2单元中,和放在SUM单元. 解:
DSEG SEGMENT
MEM1 DW 1122H,3344H
MEM2 DW 5566H,7788H SUM DW 2 DUP(?) DSEG ENDS
CSEG SEGMENT
ASSUME CS:CSEG,DS:DSEG START: MOV AX,DSEG MOV DS,AX LEA BX,MEM1 LEA SI,MEM2 LEA DI,SUM MOV CL,2 CLC
AGAIN: MOV AX,[BX] ADC AX,[SI] MOV [DI],AX ADD BX,2 ADD SI,2 ADD DI,2 LOOP AGAIN HLT
CSEG ENDS END START
4.4试编写程序,测试AL寄存器的第4位(bit4)是否为0?
解: 测试寄存器AL中某一位是否为0,可使用TEST指令、AND指令、移位指令等几种方法实现。 如:TEST AL,10H JZ NEXT . . .
NEXT:…
或者: MOV CL,4 SHL AL,CL JNC NEXT .
NEXT:…
4.7执行下列指令后,AX寄存器的内容是多少? TABLE DW 10,20,30,40,50 ENTRY DW 3 . . .
MOV BX,OFFSET TABLE ADD BX,ENTRY
MOV AX,[BX] 解:(AX)=1E00H
4.12 画图说明下列语句分配的存储空间及初始化的数据值。 (1)DATA1 DB ?BYTE?,12,12H,2 DUP(0,?,3) (2)DATA2 DW 4 DUP(0,1,2),?,-5,256H 解: (1) 存储空间分配情况如图(a)所示。 (2) 存储空间分配情况如图(b)所示。
第5章存储器系统
5.1 内部存储器主要分为哪两类? 它们的主要区别是什么? 解: (1)分为ROM 和 RAM 。 (2)它们之间的主要区别是:
ROM在正常工作时只能读出,不能写入。RAM则可读可写。 断电后,ROM中的内容不会丢失,RAM中的内容会丢失。
5.6 若采用6264芯片构成上述的内存空间,需要多少片6264芯片? 解:每个6264芯片的容量位8KB,故需432/8=54片。
5.7 设某微型机的内存RAM区的容量位128KB,若用2164芯片构成这样的存储器,需多少2164芯片?至少需多少根地址线?其中多少根用于片内寻址?多少根用于片选译码? 解:
(1)每个2164芯片的容量为64K×1bit,共需128/64×8=16片。 (2)128KB容量需要地址线17根。 (3)16根用于片内寻址。 (4)1根用于片选译码。
注意,用于片内寻址的16根地址线要通过二选一多路器连到2164芯片,因为2164芯片是DRAM,高位地址与低位地址是分时传送的。
5.9 甚什么是字扩展?什么是位扩展?用户自己购买内存条进行内存扩充,是在进行何种存储器扩展? 解:
(1)当存储芯片的容量小于所需内存容量时,需要用多个芯片构成满足容量要求的存储器,这就是字扩展。
(2)当存储芯片每个单元的字长小于所需内存单元字长时,需要用多个芯片构成满足字长要求的存储模块,这就是位扩展。
(3)用户在市场上购买内存条进行内存扩充,所做的是字扩展的工作。
5.10 74LS138译码器的接线图如教材第245页的图5-47所示,试判断其输出端Y0#、Y3#、Y5#和Y7#所决定的内存地址范围。
解:因为是部分地址译码(A17不参加译码),故每个译码输出对应2个地址范围:
Y0#:00000H ~ 01FFFH 和 20000H ~ 21FFFH Y3#:06000H ~ 07FFFH 和 26000H ~ 27FFFH Y5#:0A000H ~ 0BFFFH 和 2A000H ~ 2BFFFH Y7#:0E000H ~ 0FFFFH 和 2E000H ~ 2FFFFH