jmp:一个近跳转的问题

本文探讨了汇编中的jmp near指令的跳转范围,并通过实例展示了在不同情况下,如16位和32位模式下,跳转范围的变化。通过测试和反汇编代码分析,得出nasm编译器允许0-65535范围内的跳转地址,但实际跳转可能受到指令长度和地址表示方式的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前天,复习汇编时,看到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反汇编代码分

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值