1

我正在尝试在 MIPS 中编写一个 strlen 子例程。该函数在字符串在内存中时起作用,但如果字符串是用户的输入,则答案始终为 = (correct_value + 1)。例如:

String: Hello
Length: 6

为什么它不适用于输入?这是我的代码。我正在使用火星。

    .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
4

1 回答 1

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 结尾,你就有一个终止字符。

祝你好运!

于 2015-01-06T01:42:37.697 回答