内容发布更新时间 : 2024/12/22 19:00:13星期一 下面是文章的全部内容请认真阅读。
完美WORD格式.整理
第3章寻址方式及指令系统
1、指令是CPU可以理解并执行的操作命令,指令由操作码和操作数两部分组成,指令有两个级别,即机器级和汇编级。 2、请画出程序执行流程示意图。
3、指令主要有哪些分类方式及其主要类别是什么?
答:指令分类有不同的方式。按操作数的个数将指令分为零地址指令(无操作数)、一地址指令(只有一个操作数)、二地址指令(有两个操作数)、多地址指令(多于两个操作数);按指令级别分为机器指令和汇编指令:按是否转移分为转移指令和顺序指令;按功能分为七大类:传送类、算术运算类、位操作类、I/O类、串操作类、CPU控制类、转移类;按指令长度(即指令占用的字节数)分为l字节指令、2字节指令等,8086/8088指令长度是不同的,叫变字长,不同的指令有不同的指令长度,从1~6字节均有;按指令执行期间取操作数是否需要与总线打交道分为内部指令(不需)和外部指令(需要),类似功能的指令内部指令比外部
. 专业资料分享 .
完美WORD格式.整理
指令执行速度快,所以在编程时尽量采用内部指令即多用寄存器优化程序。 4、操作数的寻址方式有哪些?并举例说明其主要特点。
答:操作数寻址方式主要有立即寻址方式、寄存器寻地址、存储器寻址方式、端口寻址方式4类。
(1)立即寻址方式:操作对象是这个操作数本身,MOV AL,5 (2)寄存器寻地址:操作对象是寄存器中的内容MOV AX,BX
(3)存储器寻址方式:操作对象是内存地址所对应的存储单元中的内容,MOV AX [2000H]
(4)端口寻址方式:操作数是指明端口的地址、端口地址所对应的端口中的内容是操作对象IN AX,46直接寻址。
5、内存寻址中段寄存器与段内偏移地址对应关系如何?
6、设CS=1000H,DS=2000H,ES=3000H,SS=4000H,IP=100H,SP=200H,BX=300H,BP=400H,SI=500H,则①下一条待执行指令的物理地址为多少?②当前栈顶的物理地址为多少?③[BX]代表的存储单元的物理地址为多少?④[BP]代表的存储单元的物理地址为多少?⑤ES:[BX+SI]代表的存储单元的物理地址为多少? 答:①下一条待执行指令的物理地址=CS×16+IP=1000H×16+IOOH=10100H。
. 专业资料分享 .
完美WORD格式.整理
②当前栈顶的物理地址=SS×16+SP=4000H×16+200H=40200H。
③[BX]代表的存储单元物理地址=DS×16+BX=2000H X l6+300H=20300H。 ④[BP]代表的存储单元物理地址=SS X l6+BP=4000H×16+400H-----40400H。
⑤
ES
:
[BX+SI]
代
表
的
存
储
单
元
物
理
地
址
=ES×16+BX+SI=3000H×16+300H+500H=30800H 7、试根据以下要求,分别写出相应的汇编语言指令。
(1)以寄存器BX和DI作为基址变址寻址方式把存储器中的一个字送到DX寄存器。 答:MOV DX,[BX+DI]
(2)以寄存器BX和偏移量VALUE作为寄存器相对寻址方式把存储器中的一个字和AX相加,把结果送回到那个字单元。 答:ADD VALUE[BX],AX
(3)将1字节的立即数0B6H与以SI作为寄存器间接寻址方式的字节单元相比较。 答:CMP BYTE PTR[SI],0B6H (4)将BH的高4位与低4位互换。 答:MOV CL,4 ROR BH,CL
;或者ROL BH,CL
(5)测试BX的第3、7、9、12、13位是否同时为0。 答:TEST BX,3288H
;0011001010001000B
(6)将存放了0~9数值的DL寄存器中的内容转化为相应的‘0’~‘9’的字符。 答:ADD DL,30H
;或者OR DL,30H
(7)将存放了‘A’~‘F’字符的AL寄存器中的内容转化为相应的数值。 答:SUB AL,37H
. 专业资料分享 .
完美WORD格式.整理
8、写出清除AX寄存器的多种方法并比较(要求单指令实现)。 答:
(1)AND AX,0 ZF、PF标志位。
(2)MOV AX,0
;此条指令占用3个字节。
;可以对AX清零,还可以清除进位位和影响到SF、
(3)SUB AX,AX ;减法指令, 该条指令只占用2个字节。 (4)XOR AX,AX
9、分别用存储器的5种寻址方式实现将以A为首址的第5个字(注意:从第0个算起)送AX的指令序列。
10、指出下列指令错误的原因。
答:(1)MOV CL,300 ;300超过字节数据表示范围 (2)MOV CS,AX ;CS不能作为目的操作数 (3)MOV BX,DL ;数据类型不匹配
(4)MOV ES,1000H :立即数不能送给段寄存器 (5)INC [BX] ;数据类型不明确 ’ (6)ADD AX,DS :段寄存器不能参加运算
(7)TEST BX,[CX] ;存储器间接寻址只能使用BX、Sl、Dl、BP四个之一
(8)SUB [BX],[BP+SI] ;加减两个操作数不能同时为存储操作数 (9)JC [SI] ;条件转移只有短转移寻址方式
(10)SHL BX ;少给一个表明移位次数的操作数,l或CL
. 专业资料分享 .