赞
踩
ptr的作用就是临时指定类型。8086CPU的指令,可以处理两种尺寸的数据,byte和word。所以在机器指令中要指明,指令进行的是字操作还是字节操作。对于这个问题,汇编语言中用以下方法处理。
1. 通过寄存器名指明要处理的数据的尺寸。
例如:
下面的指令中,寄存器指明了指令进行的是字操作是字操作:
mov ax,3
mov bx,ds:[4]
mov ds,ax
mov ds:[1],ax
inc ax
add ax,1000
下面的指令中,寄存器指明了指令进行的是字节操作:
mov al,1
mov al,bl
mov al,ds:[0]
mov ds:[0],al
inc al
add al,100
2.在没有寄存器名存在的情况下,用操作符 X ptr 指明内存单元的长度
X在汇编指令中可以是byte(字节)、word(字)、dword(双字)、qword(四字)、tbyte(十字节)、far(远类型)和near(近类型)
例:
mov byte ptr ds:[0],1
mov word ptr ds:[0],1
jmp near ptr 标号
3. 指令默认
有些指令默认了访问的是字单元还是字节单元,比如:push、pop指令就不用指明访问的是字单元还是字节单元,因为它们只进行字操作。
可以修改IP,或同时修改CS和IP的指令统称为转移指令。
无条件转移指令,可以只修改ip也可同时修改cs与ip。
jmp指令要给出两种信息:
(1)转移的目的地址
(2)转移的距离(段间转移。段内短转移,段内近转移)
不同的给出目的地址的方法与不同的转移位置,对应有不同格式的jmp指令。
1,根据位移
这两条指令对应的机器码中并不包含转移的目的地址,而包含的是相对于当前IP的转移位移。
jmp short 标号 ip=ip+8位位移 段内短转移
其中,short指明此处的转移位移为8位,由编译程序在编译时计算得出。位移计算方法为标号处的地址 - jmp指令后的第一个字节的地址,8位位移的范围是-2^7 至2的7次方-1
jmp near ptr 标号 ip=ip+16位位移 段内近转移
其中near ptr指明转移位移为16位,其余同上。
2.转移的目的地址在指令中
jmp far ptr 标号 段间转移,又称远转移
far ptr指明了指令用标号的段地址和偏移地址修改cs和ip,cs=标号所在段的段地址,ip=标号在段中的偏移地址
3.转移地址在寄存器中
Jmp reg(16位)
ip=(16位reg)
4.转移地址在内存中
jmp word ptr 内存单元地址 (段内转移)
ip=(内存单元地址 )
jmp dword ptr 内存单元地址 (段间转移)
cs=(内存单元地址+2 )
ip=(内存单元地址 )
短转移,对应的机器码中包含转移的位移,而不是目的地址。
jcxz 标号
if cx=0,ip=ip+8位位移,转移到标号处执行
if cx≠0,程序向下执行
相当于 if(cx==0)jmp short 标号
循环指令,所有的循环指令都是短转移,对应的机器码中包含转移的位移,而不是目的地址。
loop 标号
(cx)=(cx)-1
if(cx)≠0,IP=(IP)+8位位移
相当于:
(cx)- -;
if(cx≠0)jmp short 标号
(1)将当前的IP或CS和IP压入栈中;
(2)转移
无法实现短转移
1.根据位移转移的CALL指令
call 标号
(1)(SP)=(SP) - 2
((SS)*16+(SP))=(IP)
(2) (IP)=(IP)+16位位移
16位位移=标号处的地址 - CALL指令后的第一个字节地址
相当于:
PUSH IP
jmp near ptr 标号
2.转移目的地址在指令中
call far ptr 标号 段间转移
(1)(SP)=(SP) - 2
((SS)*16+(SP))=(CS)
(SP)=(SP) - 2
((SS)*16+(SP))=(IP)
(2)(CS)=标号所在段的段地址
(IP)=标号所在段中的偏移地址
相当于:
PUSH CS
PUSH IP
JUMP FAR PTR 标号
3.转移地址在寄存器中
CALL 16位reg
(1)(SP)=(SP) - 2
((SS)*16+(SP))=(IP)
(2) (IP)=(16位reg)
相当于
PUSH IP
jmp 16位reg
4.转移地址在内存中
(1)call word ptr 内存单元地址
(2)call dword ptr 内存单元地址
ret
(1) (IP)=((SS)*16+(SP))
(2) (SP)=(SP) +2
相当于 pop ip
retf
(IP) = ((SS)*16+(SP))
(SP)=(SP) + 2
(cs) = ((SS)*16+(SP))
(SP)=(SP) + 2
相当于
pop ip
pop cs
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。