对不起再打扰一下.我正在努力了解学习集会语言.但是我有很多问题.我正在尝试使用NASM中的字符串.我已将字符串常量复制到字符串变量.最大大小为50.所以我想验证这个绑定.但是这个程序会引发分段错误.我在MASM中使用了一个示例,因此可能存在使用NASM语法的使用错误.
我的计划如下:
section .data MAXTEXTSIZE equ 50 _cte_hola db "Hola",0 _cte_mundo db "Mundo",0section .bss MAIN_d resb MAXTEXTSIZE+1section .text global _startstrlen: mov bx,0 strl01: cmp WORD [SI+BX],0 t je strend inc bx jmp strl01strend: retstrcpy: call strlen cmp bx,MAXTEXTSIZE jle copiarsizeok mov bx,MAXTEXTSIZEcopiarsizeok: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中,你必须比较字节[esi ebx],0而不是字.
>不要在linux中设置段寄存器.它们将由 *** 作系统设置,您无法触摸它们.在linux中,所有内存都是一个平面区域,您不必再使用段寄存器. 总结
以上是内存溢出为你收集整理的strlen in NASM Linux全部内容,希望文章能够帮你解决strlen in NASM Linux所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)