你没有给我们提供了很多的信息去,所以我会假设你的文件看起来是这样的:
1234 523 54326 7131
(可以线分隔,这个概念是一样的)
将数字读入字符串后,必须将其解析为整数。然后将其存储在整数数组中。你的阵列应该是这个样子:
.align 2 # word-aligned
array: .space 40 # a word array of 10 elements
为了解析字符串为整数,你可以手推车从C,它具有的atoi(),它看起来是这样的概念:
#
# int atoi (const char *str);
#
# Parse the cstring str into an integral value
#
atoi:
or $v0, $zero, $zero # num = 0
or $t1, $zero, $zero # isNegative = false
lb $t0, 0($a0)
bne $t0, '+', .isp # consume a positive symbol
addi $a0, $a0, 1
.isp:
lb $t0, 0($a0)
bne $t0, '-', .num
addi $t1, $zero, 1 # isNegative = true
addi $a0, $a0, 1
.num:
lb $t0, 0($a0)
slti $t2, $t0, 58 # *str <= '9'
slti $t3, $t0, '0' # *str < '0'
beq $t2, $zero, .done
bne $t3, $zero, .done
sll $t2, $v0, 1
sll $v0, $v0, 3
add $v0, $v0, $t2 # num *= 10, using: num = (num << 3) + (num << 1)
addi $t0, $t0, -48
add $v0, $v0, $t0 # num += (*str - '0')
addi $a0, $a0, 1 # ++num
j .num
.done:
beq $t1, $zero, .out # if (isNegative) num = -num
sub $v0, $zero, $v0
.out:
jr $ra # return
(只就像C atoi()函数一样,它没有错误检查机制,你可能想补充一下)。
从文件解析每个单独的数字(通过传递给atoi())并将其作为整数存储在数组中。
非常感谢帮助! :) – Amjad 2012-04-13 10:51:02