我正在尝试在MIPS中编写strlen子例程。 当字符串在内存中时,该函数有效,但如果字符串是用户的输入,则答案始终为=(correct_value + 1)。 例如:
String: Hello
Length: 6
为什么它不适用于输入?这是我的代码。我正在使用MARS。
.data
str1: .asciiz String: "
strTest:.space 20
str2: .asciiz "Length: "
.text
.globl main
main:
addiu $sp, $sp, -4 # save space
sw $ra, 0($sp) # push $ra
la $a0, str1 # print(str1)
li $v0, 4
syscall
li $a1, 20 # read strTes
la $a0, strTest
li $v0, 8
syscall
jal strlen # call strlen
move $t0, $v0 # save result to $t0
la $a0, str2 # print str2
li $v0, 4
syscall
move $a0, $t0 # print result
li $v0, 1
syscall
lw $ra, 0($sp) # restore $ra
addiu $sp, $sp, 4 # restore $sp
jr $ra
strlen:
li $v0, 0 # len = 0
while: lb $t0, ($a0) # get char
beqz $t0, wh_end # if(char == '\0') --> end while
addi $v0, $v0, 1 # len++
addiu $a0, $a0, 1 # *s++
j while
wh_end:
jr $ra
答案 0 :(得分:3)
我的猜测是,MARS还包括用户输入他/她的字符串后按下的输入/返回。您的代码看起来很好,因此MARS返回"hello\n"
代替"hello"
是最符合逻辑的,就像您希望的那样。
要解决此问题,您可以像对"\0"
一样添加支票,然后为"\n"
添加支票。我不确定它是否可行,但您可以尝试添加
subi $t1, $t0, 10
beqz $t1, wh_end
在beqz $t0, wh_end
之后。这可能有效,因为\ n终止字符的ASCII值为10,所以如果从$ t0中减去10,最后得到0,则会有终止字符。
祝你好运!