offset操作
start: mov ax offset start 相当于mov ax, 0
s: mov ax, offset s 相当于mov ax, 3
1. jmp指令
- jmp无条件跳转,可以只修改IP
- jmp指令需要给出两种信息:转移的目的地址,转移的距离
jmp short 标号/ jmp near ptr 标号进行的都是"段内"转移,jmp far ptr 标号,可以进行“段间的转移”
1.1 jmp short 标号:转移到标号处执行指令
- 实现段内短距离转移,他对IP的修改范围是-128~127,也就是最多可以在当前位置前128后127个字节的位置转移

- jmp short s指令的执行过程

所以jmp翻译成机器码,其实是一个偏移的书,EB03,向前偏移3位。

1.2 jmp near ptr 标号:类似jmp short 标号,只是位移是16位,进行的是段内的近转移。
1.3 jmp far ptr 标号
- 功能

- jmp far ptr 翻译成机器码包含转移的目的地址,前两个jmp给的是偏移地址。

1.4 jmp 16位寄存器
1.5 jmp转移地址在内存中
- jmp word ptr 内存单元地址

1.6 jmp dword ptr 内存单元地址
- 高位对应段地址,低位对应偏移地址
- (CS) = (内存单元地址+2)
- (IP) = (内存单元地址)

2. jcxz指令:有条件跳转指令
- 对应机器码中包含转移的位移,而不是目的地址,对IP的修改范围为-128~127
指令格式:jcxz 标号;如果(cx) = 0,则转移到标号处执行。如果(cx) != 0程序什么也不做,继续往下执行
3. loop指令,循环指令
对IP的修改范围是-128~127
4. 根据位移进行转移的意义:jmp short 标号;…
- 这样涉及是为了方便程序段在内存中的浮动装配
- 根据位移进行转移的指令,转移范围是收到转移位移大小的限制,如果超过这个范围,编译就会报错。
nop指令,就是空,占一个字节