如何在java中转换保持相同值的十六进制字符串。
在C中我有:
char tab[24] = { 0x02, 0x04, 0xF3, 0xFC, 0xFF, 0x06, 0x00, 0xF7, 0x00, 0x00, 0x09, 0xFD, 0xFD, 0x00, 0x03, 0x0A, 0xFD, 0x02, 0xFD, 0x08, 0x08, 0x00, 0x01, 0xFD };
我像一个字符串一样复制到java;
String hexString = "0x02, 0x04, 0xF3, 0xFC, 0xFF, 0x06, 0x00, 0xF7, 0x00, 0x00, 0x09, 0xFD, 0xFD, 0x00, 0x03, 0x0A, 0xFD, 0x02, 0xFD, 0x08, 0x08, 0x00, 0x01, 0xFD";
现在我想转换为byte [],我找到了一些方法,但它看起来好像我没有以正确的格式转换。
解决
String[] split = hexString.split(", ");
byte[] arr = new byte[split.length];
for (int i = 0; i < split.length; i++)
{
arr[i] = (byte)(short)Short.decode(split[i]);
}
答案 0 :(得分:3)
如果你真的想将给定的字符串转换为byte[]
(虽然这似乎是一个奇怪的要求)......
String hexString = "0x02, 0x04, 0xF3, 0xFC, 0xFF, 0x06, 0x00, 0xF7, 0x00, 0x00, 0x09, 0xFD, 0xFD, 0x00, 0x03, 0x0A, 0xFD, 0x02, 0xFD, 0x08, 0x08, 0x00, 0x01, 0xFD";
String[] split = hexString.split(", ");
byte[] arr = new byte[split.length];
for (int i = 0; i < split.length; i++)
{
arr[i] = (byte)Short.parseShort(split[i].substring(2), 16);
}
System.out.println(Arrays.toString(arr));
我们需要使用parseShort
代替parseByte
,因为尝试使用0xF3
解析parseByte
之类的内容会导致NumberFormatException: Value out of range
。
打印:
[2, 4, -13, -4, -1, 6, 0, -9, 0, 0, 9, -3, -3, 0, 3, 10, -3, 2, -3, 8, 8, 0, 1, -3]
答案 1 :(得分:2)
你在C中所拥有的将是Java:
byte[] tab = { 0x02, 0x04, (byte) 0xF3, (byte) 0xFC, (byte) 0xFF, 0x06,
0x00, (byte) 0xF7, 0x00, 0x00, 0x09, (byte) 0xFD, (byte) 0xFD,
0x00, 0x03, 0x0A, (byte) 0xFD, 0x02, (byte) 0xFD, 0x08,
0x08, 0x00, 0x01, (byte) 0xFD };
请注意,您使用char
代替byte
,并且byte
的允许范围之外的值(例如0xFD)需要显式强制转换。并且您不在声明中包含数组长度。
更新:要不手动添加强制转换,您可以声明更宽类型的数据(如int或short),然后循环遍历它:
int[] temp = { ... };
byte[] tab = new byte[temp.length];
for (int i = 0; i<temp.length; i++) tab[i]=(byte)temp[i];
更好的解决方案是从外部文件加载数据。大数组文字不会像C编译器编码大数组文字那样以紧凑的方式编码到类文件中。
答案 2 :(得分:0)
String hex = "0xFFFFFFFF";
long longRep = Long.decode(hex);
byte[] byteRep = String.valueOf(intrRep).getBytes("UTF-8");
//to verify
System.out.println(Long.toHexString(Long.valueOf(new String(byteRep,"UTF-8"))));