将little-endian转换为ASCII

时间:2017-04-01 18:23:01

标签: string hex ascii endianness

我需要帮助转换little-endian字符串

8989d0261ee17bbf95ea5596711538b0

到ASCII。有人可以指导我完成这个过程吗?

我不确定这是否正确,但我相信我可以通过执行以下操作将此字符串转换为十进制:

8 * 16 ^(字符串长度)+ 9 * 16 ^(字符串长度 - 1)+ ... + 0 * 16 ^ 0

(将字符串的值乘以它的位置)。然后,一旦我得到它,我减去2 ^ 32,我将得到十进制的等价物。然后,我可以使用在线转换器将十进制数转换为ASCII。这会有用吗?

1 个答案:

答案 0 :(得分:0)

你的推理是正确的。

如果您在基数10中有一个数字,例如259,则该数字可以重写为

2 * 10 ^ 2 + 5 * 10 ^ 1 + 9 * 10 ^ 0。

类似地,在上面的示例中,字符串中的每个字符都分配了一个值(类似于十六进制)。我看到你的等式中的转换部分是正确的。 二进制补码是对二进制数的运算,用于表示有符号数。按照这种方法,我们必须减去2 ^ 32以获得十进制的等效值。

请注意,也可以执行类似的反向操作来实现ASCII表示(如果您无法使用转换器)。

以下是一个包​​含许多示例的链接,您可能会对此感兴趣:https://www.cs.cornell.edu/~tomf/notes/cps104/twoscomp.html