在以下程序中,我将十六进制字符串“0123456789ABCDEF”转换为二进制。
public static void main(String[] args) {
// TODO Auto-generated method stub
String key = "0123456789ABCDEF"; //hexadecimal key
char[] keyCharArray = key.toCharArray();
for (int i = 0; i < key.length(); i++) {
System.out.print(HexToBinary((keyCharArray[i]))+",");
}
}
public static String HexToBinary(char Hex) {
int i = Integer.parseInt(Character.toString(Hex), 16);
String Bin = Integer.toBinaryString(i);
return Bin;
}
我得到以下输出
0,1,10,11,100,101,110,111,1000,1001,1010,1011,1100,1101,1110,1111,
但我要求输出如下
0000,0001,0010,0011,0100,0101,0110,0111,1000,1001,1010,1011,1100,1101,1110,1111,
0x
我发现的一种方法是在每个十六进制字符前面附加。如下:
0x0, 0x1, 0x2,............,0xE,0xF
另一种方法是手动检查输出缺少 4 个字符,并将这些字符附加0
到它上面。但是我不知道如何在上面的代码中实现前者。有没有什么有效的方法来做我上面想做的事情?