在开始接触AT&T编程时,将一个大于255的数字输出,一直是一个很大的问题,这个问题困扰了我很久很久,一直到前段时间自己摸索,调试,才最终把这个大问题解决。
首先,让我们回顾一下AT&T中怎么做除法,将被除数保存到%eax中,将除数保存到另外的寄存器中,做DIV运算,除得商在%eax中,余数在%edx中。
好的,我们切入正题,我们先申请一块字符串区域,将要输出的数字保存在%eax中,每次将%eax中的内容除以10,然后把余数加上0的ASKII码值48。那么怎样才能转为字符串,其实很简单,只要把ASKII码值依次存到字符串区域,就会自动把数字转为字符串。
由于除法做完后所得到的余数存入字符串区域的顺序与要输出的顺序相反,而汇编中寄存器比较少,所以我们需要把数据压入栈中,正好出栈换了一下顺序。
好了,我们看下代码
#将数字转为字符串
.section .bss
.lcomm buff ,30
.section .data
temp:
.string ""
.section .text
.globl _start
_start:
movl $1234, %eax
movl $0, %edi
movl $0, %esi
loop:
xorl %edx,%edx
cmp $0, %eax
je loop_pop
movl $10, %ebx
divl %ebx
addl $48, %edx #将余数转为ASKII数
pushl %edx
incl %edi
#将栈中数取出
loop_pop:
cmp $0, %edi
je exit
popl %eax
movl %eax, temp(,%esi,1)
decl %edi
incl %esi
jmp loop_pop
exit:
movl $10, temp(,%esi,1) #换行
movl $30, %edx
movl $temp, %ecx
movl $1, %ebx
movl $4, %eax
int $0x80
movl $0,%ebx
movl $1, %eax
int $0x80
好了,到这里也差不多该结束了,有不懂的地方可以在下方留言,我看见了就会答复您的。希望这篇文章可以帮到您。