将十进制转换为二进制并以MIPS格式打印

时间:2010-10-12 23:11:53

标签: assembly mips spim

我正在编写一个简单的代码片段,我需要将十进制数转换为二进制,八进制和十六进制。我有它工作,但后来我意识到,由于我正在使用的算法,我向后打印二进制数。我使用的策略是一次打印一个数字。我还是初学者,所以我认为这是避免更多中间问题的简单方法。不幸的是,我没有想到这一切。

binary:   la        $a0, bType                            #binary function selected, notify user
          li        $v0, 4                                #print notification
          syscall
          la        $a0, in_val                           #ask user for input decimal number
          li        $v0, 4                                #print
          syscall
          li        $v0, 5                                #syscall read int
          syscall
          move      $t0, $v0                              #save input value to $t0
          li        $t1, 2                                #load 2 into $t1 to divide by 2
          li        $v0, 4
          la        $a0, bRes                            
          syscall                                         #print result tag
binLoop:  divu      $t0, $t1                              #LO = $t0/2, HI = $t0 % 2
          mfhi      $t2                                   #$t2 = HI (remainder)
          mflo      $t0                                   #$t0 = $t0/2 (quotient)
          move      $a0, $t2                              #store digit to print
          li        $v0, 1                                #Print digit
          syscall
          bgtz      $t0, binLoop                          #if input != 0, keep dividing
          j         main

有没有什么方法可以将每个数字存储到带有标签的字符串中,然后连接每个数字,然后向后读取字符串或什么?也许有一个更好的建议,你可以指出我。

请注意,此时代码通过一次打印一个二进制数字,但按照我们想要的相反顺序运行。该程序应该能够处理大数字(如20个二进制数字长),所以我不能将每个数字存储在自己的寄存器中。谢谢大家!

1 个答案:

答案 0 :(得分:0)

您可能希望将计算值存储在内存中,然后反向读取它们以打印它们。 使用一个备用寄存器来保持缓冲区中的数字偏移(打印),比如$ a1,假设您将存储从内存地址0x1000开始的数字。 然后,不要让系统调用打印数字,而是用以下内容存储它:

sw $t2, 0x1000($a1)
addiu $a1, $a1, 4

现在,当您完成输入数据的处理后,您可以按相反的顺序遍历您制作的矢量并打印每个数字:

addiu $a1, $a1, -4
lw $t2, 0x1000($a1)
# Now your code to print the digit

你必须循环,直到$ a1达到0