前天,复习汇编时,看到jmp的short跳转,跳转范围为[-128,127],马上我想到jmp的near跳转应该为[-32738,32767],并且我写了一个程序来测试这一想法,程序如下:
org 0100h
jmp LABEL_START
[SECTION .code16]
[BITS 16]
LABEL_START:
mov ax, cs
mov ds, ax
mov es, ax
mov ss, ax
mov sp, 0100h
mov ax, 0b800h
mov gs, ax ;initial segment
mov di, (80*12+12)*2
mov byte[gs:di], 'S'
jmp near LABEL_TEST
times 65530 db 0
LABEL_TEST:
add di, 2
mov byte [gs:di], 'T'
jmp $
这个跳转已经越界了,程序运行的结果(显示S)表明这一个结果,我又修改了times这条指令,将65530改为65000,重新编译运行,结果却出乎意料,打印了”ST“,十分不解。甚至以为是nasm的bug,昨天在csdn发了一个帖子,按回帖人的建议,我反汇编跟踪了几次。终于发现了问题的所在。修改前和修改后的jmp near LABEL_TEST反汇编代码分