x86 中的阶乘函数 NASM 程序集出错

Factorial function in x86 NASM assembly goes wrong

我正在使用 x86 NASM 学习汇编语言。我想编写一个简单的递归阶乘函数,我使用 EAX 寄存器将一个参数传递给该函数。之后,我想在屏幕上打印我的结果,但什么也没有发生。坐下来盯着我的电脑看后,我不知道我的代码有什么问题。你们能帮助新手解决这个问题吗?

我知道阶乘函数的序言和结尾不是必需的,因为我没有使用堆栈,但对我来说代码更具可读性;)

这是我的代码:

global main
extern printf

section .data
    message db "%03X", 0x10, 0x0

section .text
main:
    mov eax, 5
    call factorial
    push eax
    push message
    call printf
    add esp, 0x8
    mov eax, 1
    mov ebx, 0
    int 0x80

factorial:
    push ebp
    push edx
    mov ebp, esp
    mov edx, eax
    cmp edx, 0
    jne not_equal_zero
    mov eax, 1
    jmp exit
not_equal_zero:
    mov eax, edx
    sub eax, 1
    call factorial
    imul eax, edx
exit:
    mov esp, ebp
    pop edx
    pop ebp
    ret

C 库——我猜你使用的是 GCC 的库——不会立即输出 printf 的结果。相反,它存储在称为缓冲区的单独内存中并随机输出。在这种情况下,程序将比刷新缓冲区快 int 0x80/eax=1 结束。您可以插入手动冲洗:

...
extern fflush
...
push 0
call fflush
add esp, 4
...

最好的解决办法是使用Cexit函数。替换

mov ebx,0
mov eax,1
int 0x80

来自

push 0
call exit

或简单地替换为

ret

在这种情况下,您不需要手动刷新缓冲区。这将 exitret 为您效劳。

顺便说一句:LF(换行符)编码为 10 十进制 和 0x0A 十六进制。