0

在 32 位 Ubuntu 中学习 NASM 汇编。

这让我很头疼:假设我有一个数组(我在程序中称之为向量).data

vector db  1,2,3,4
size   equ $-vector

我也有一个号码0

index  db 0

我想存入sizeEBX然后存入indexECX最后检查是否ECX < EBX。在此示例中,它将是0 < 4. 我的程序根本不这样做:

SECTION .data
    vector  db  1,2,3,4
    size    equ $-vector

    index   db  0

    ; Vocabulary
    msg1    db  "ECX < EBX",10
    msg1len equ $-msg1
    msg2    db  "ECX >= EBX",10
    msg2len equ $-msg2

SECTION .text
global main
main:
; -----------------------------------------------
; MAIN
; -----------------------------------------------
    mov EBX,size     ; EBX = 4
    mov ECX,[index]  ; ECX = 0
    call    check    ; Check ECX < EBX (0 < 4)

; -----------------------------------------------
; EXIT
; -----------------------------------------------
mov EAX,1
int 0x80

; -----------------------------------------------
; Check
; Checks whether ECX < EBX
; -----------------------------------------------
check:
cmp ECX,EBX
jge greater_or_equal

mov EAX,4
mov EBX,0
mov ECX,msg1
mov EDX,msg1len
int 0x80
jmp end_check

greater_or_equal:

mov EAX,4
mov EBX,0
mov ECX,msg2
mov EDX,msg2len
int 0x80

end_check:

ret

它输出:

ECX >= EBX

但这是不对的。ECX应该是 0 并且EBX应该是 4。

我没有看到问题 - 但我确实有一个观察结果:

mov EBX,size

这条线让我很烦 - 我想这样做:

mov EBX,[size]

但是我会遇到分段错误。我不知道会发生这种情况,但我猜这是因为size它不是地址 - 它只是一个数字,所以我不能使用它上面的括号。我可能错了(在这种情况下,这可能是问题的原因)。

4

1 回答 1

1
index   db  0
msg1    db  "ECX < EBX",10

mov  ecx, [index] 

index被定义为db,因此指令ecx将从msg1

利用:

index dd 0
于 2013-09-16T04:06:44.473 回答