汇编-jmp无条件转移指令
jmp short 标号(转到标号处执行指令)
这种格式的jmp指令实现的是段内短转移,它对IP的修改范围为-128~127,也就是说,它向前转移时可以最多越过128个字节,向后转移可以最多越过127个字节。jmp指令中的“short”符号,说明指令进行的是短转移。jmp指令中的“标号”是代码段中的标号,指明了指令要转移的目的地,转移指令结束后,CS:IP应该指向标号处的指令。
assume cs:codesg,ds:datasg datasg segment;数据段 datasg ends codesg segment start: mov ax,0 jmp short s add ax,10 s:inc ax codesg ends end start
jmp near ptr 标号
功能为:(IP)=(IP)+16位位移
16位位移的范围为-32768~32767,用补码表示;
jmp far ptr 标号
assume cs:codesg,ds:datasg datasg segment;数据段 datasg ends codesg segment start: mov ax,0 jmp far ptr s;实现段间转移,far ptr 指明了指令用标号的段地址和偏移地址修改CS和IP。 add ax,10 db 256 dup(0) s:inc ax codesg ends end start
jmp 16位寄存器
功能:(IP)=(16位reg)
jmp word ptr内存单元地址(段内转移)
mov ax,0123h mov ds:[0],ax jmp word ptr ds:[0]; 执行后(IP)=0123H add ax,10
mov ax,0123h mov bx,ax jmp word ptr [bx]; 执行后(IP)=0123H add ax,10
jmp dword ptr内存单元地址(段间转移)
功能:从内存单元地址处开始存放着两个字,高地址处的字是转移的目的段地址,低地址处是转移的目的偏移地址。
mov ax,0123H mov ds:[0],ax mov word ptr ds:[2],0 jmp dword ptr ds:[0] ;执行后,(CS)=0,(IP)=0123H,CS:IP指向0000:0123
mov ax,0123H mov [bx],ax mov word ptr [bx+2],0 jmp dword ptr [bx] ;执行后,(CS)=0,(IP)=0123H,CS:IP指向0000:0123