我正在使用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
我猜你使用 GCC 中的库 - 不会立即输出printf
的结果。相反,它存储在称为缓冲区的单独内存中,并偶然输出。在这种情况下,程序的结束速度将比刷新缓冲区快int 0x80/eax=1
。您可以插入手动冲洗:
...
extern fflush
...
push 0
call fflush
add esp, 4
...
最好的解决方案是使用 C exit
函数。取代
mov ebx,0
mov eax,1
int 0x80
由
push 0
call exit
或简单地将其替换为
ret
在这种情况下,无需手动刷新缓冲区。这将exit
或ret
为您做。
顺便说一句:LF(换行(编码为 10 个十进制和0x0A十六进制。