MIPS输出包括再次运行程序时的先前输出

时间:2014-04-29 05:33:03

标签: assembly mips spim qtspim

您好我有一个程序,它将按字母顺序排列用户输入的20个字符的字符串,同时还过滤掉不是小写字母的字符。我有一个带有递归循环的字母顺序的程序,然后有一个更简单的过滤器设置来清除不是小写字母的字符。我可以让程序正确地按字母顺序排列并过滤掉字符,一旦发生这种情况,程序会询问用户是否想再试一次。这是我遇到问题的地方,当前一个字符串长于后续字符串时,剩下的字符就会打印出来。

例如,如果第一个字符串按字母顺序排列为abcdefgxyz而第二个字符串只应为abcdefg,则输出仍将显示xyz。

任何帮助将不胜感激!

这是我的代码

        .text
main:   la $a0, prompt    
        li $v0, 4
        syscall

        la $a0, input   
        li $a1, 21      
        li $v0, 8
        syscall

        la $t0, input
        la $t7, input
        la $t5, final

loop:   lb $t1, 0($t0)          
        lb $t2, 1($t0)
        ble $t1, $t2, incr
        beqz $t2, filter
        jal swap        
        j loop          

incr:   addi $t0, $t0, 1
        j loop

filter: lb $t3, 0($a0)
        blt $t3, 0x61, next
        bgt $t3, 0x7a, next
        sb $t3, 0($t5)
        add $t5, $t5, 1

next:   beqz $t3, output
        addi $a0, $a0, 1
        j filter

output: la $a0, display
        li $v0, 4
        syscall
        la $a0, final
        syscall
        la $a0, again
        syscall
        li $v0, 12
        syscall

        beq $v0, 0x79, clr
        j end

clr:    li $a0, 0x0a
        li $v0, 11
        syscall
        j main

end:    la $a0, termin
        li $v0, 4
        syscall
        li $v0, 10       
        syscall

swap:   sub $sp, $sp, 4         
        sw $ra, ($sp)           
        sb $t1, 1($t0)          
        sb $t2, 0($t0)
        beq $t0, $t5, return    
        sub $t0, $t0, 1         
        lb $t1, 0($t0)          
        lb $t2, 1($t0)
        ble $t1, $t2, return    
        jal swap        

return: addi $t0, $t0, 1        
        lw $ra, ($sp)
        addi $sp, $sp, 4
        jr $ra


        .data
prompt: .asciiz "Please enter a string to alphabetize and filter: "
display:.asciiz "\nThe alphabetized and filtered string is: "
again:  .asciiz "\nDo you want to try again (y for yes)? "
termin: .asciiz "\nProgram terminated."
input:  .space 21
final:  .space 21

1 个答案:

答案 0 :(得分:0)

看起来syscall$v0=8的{​​{1}}不会终止您的输入字符串。也许有一个不同的系统调用可以做到这一点。

如果没有,那么在使用input致电syscall之前,您应该使用零覆盖$v0=8缓冲区。