程序集8086中的分支表

时间:2016-09-21 08:48:41

标签: assembly x86-16

我尝试在程序集8086中执行分支表。

我写了:

    org 100h                       

    ; START THE PROGRAM

    mov si, 1
    jmp cs:table[si]

    table dw C1, C2, C3

C1:
    add bx, 1
    jmp EXIT

C2:
    add bx, 2
    jmp EXIT

C3:
    add bx, 3
    jmp EXIT
C4:  
    add bx, 4
    jmp EXIT

; EXIT PRORGRAM   
EXIT:
    mov ah, 0
    int 16h
    ret

代码无效,它跳转到错误的标签。

有人可以举例或修改我的代码吗?

1 个答案:

答案 0 :(得分:9)

小心

jmp cs:table[si]

实际上是

的错误版本
jmp cs:[table + si]

它不是数组索引 汇编语言没有类型,为避免混淆,请不要使用这种非正统的语法。

假设table从1000h开始。然后

Table in memory at 1000h

使用SI = 1,跳转到的偏移量取自1000h + 1 = 1001h 该位置的WORD占用1001h和1002h,因此它穿过 C1 C2

直接使用索引来访问数组是装配中不可用的一种方法,我们需要根据项目的大小来缩放索引。
在这种情况下,每个项目都是WORD,2个字节,因此索引必须按2缩放。

Index    Scaled index    Address accessed
 0            0             1000h
 1            2             1002h
 2            4             1004h

因此

 mov si, 1
 shl si, 1         ;Scale index, SI = SI*2^1 = SI*2
 jmp cs:table[si]

或更好,如果索引在“编译时”

已知
 mov si, 2         ;Use scaled index directly
 jmp cs:table[si]