程序集:试图写入文件,但文本附加到文件名

Assembly: trying to write to file, but text is appending to filename

我正在尝试学习汇编,但在尝试教程中的示例时遇到了困难。我正在使用 ubuntu 虚拟机编译它。

代码如下:

SYS_READ equ 3
SYS_WRITE equ 4
SYS_OPEN equ 5
SYS_CLOSE equ 6
SYS_CREATE equ 8
SYS_EXIT equ 1

section .text
    global _start

_start:
    mov eax, SYS_CREATE
    mov ebx, filename
    mov ecx, 0777
    int 0x80

    mov [fd_out],ebx

    mov eax,SYS_WRITE
    mov edx,len
    mov ecx,msg
    mov ebx,[fd_out]
    int 0x80

    mov eax,SYS_CLOSE
    mov ebx,[fd_out]
    int 80h

    mov eax,SYS_OPEN
    mov ebx,filename
    mov ecx,0
    mov edx,0777
    int 0x80

    mov [fd_in],eax

    mov eax, SYS_READ
    mov ebx,[fd_in]
    mov ecx,info
    mov edx,26
    int 0x80

    mov eax,SYS_WRITE
    mov ebx,1
    mov ecx,info
    mov edx,26
    int 0x80

    mov eax,SYS_EXIT
    mov ebx,0
    int 0x80

section .data
    filename db 'test.txt'
    msg db 'Hello world file'
    len equ $-msg

section .bss
    fd_out resb 1
    fd_in resb 1
    info resb 26

执行编译输出后,我得到一个名为test.txtHello world file的文件。

虽然 SYS_WRITE 接受 EDX 中的信息长度,但函数 SYS_CREATE 需要一个指向文件名的 NULL 终止字符串的指针。

你的文件名,定义为

filename db 'test.txt'

不是 NULL 终止的,这就是它与下一个字符串连接的原因:

msg db 'Hello world file'

本例中的终止 NULL 是下一个定义的:

fd_out resb 1

为了修复它,只需用零终止字节定义文件名:

filename db 'test.txt', 0