再次打扰一下。我正在尝试理解学习汇编语言。但是我有很多问题。我正在尝试使用 NASM 中的字符串。我已将字符串常量复制到字符串变量。最大大小为 50。所以我想验证这个界限。但是这个程序抛出一个段错误。我在 MASM 中使用了一个示例,因此可能存在 NASM 语法的使用错误。 我的程序如下:
section .data
MAXTEXTSIZE equ 50
_cte_hola db "Hola", 0
_cte_mundo db "Mundo", 0
section .bss
MAIN_d resb MAXTEXTSIZE+1
section .text
global _start
strlen:
mov bx, 0
strl01:
cmp WORD [SI+BX],0 t
je strend
inc bx
jmp strl01
strend:
ret
strcpy:
call strlen
cmp bx, MAXTEXTSIZE
jle copiarsizeok
mov bx, MAXTEXTSIZE
copiarsizeok:mov cx, bx
cld
rep movsb
mov al,0
mov BYTE [DI], al
ret
_start:
mov ds, ax
mov es, ax
mov si, [MAIN_d]
mov di, [_cte_hola]
call strcpy
mov eax, 1
mov ebx, 0
int 80h
在此先感谢并打扰一下。我的问题对于汇编程序员来说很愚蠢。
最佳答案
我相信您正在尝试在 Linux 中制作 32 位程序,但您的示例是 16 位的。
在 Linux 中,所有指针都是 32 位的。因此,请使用扩展寄存器:esi、edi、ebx 等。您仍然可以将 8 位和 16 位寄存器用于算术和数据处理,但不能用作内存指针。
在 strlen 中,您必须比较
byte [esi+ebx], 0
而不是 word。不要在 Linux 中设置段寄存器。它们将由操作系统设置,您无法触摸它们。在 Linux 中,所有内存都是一个平面区域,您不必再使用段寄存器。
关于linux - NASM Linux 中的 strlen,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19797609/