byte[] bytes = {-1, 0, 1, 2, 3 };
StringBuilder sb = new StringBuilder();
for (byte b : bytes) {
sb.append(String.format("%02X ", b));
}
System.out.println(sb.toString());
// prints "FF 00 01 02 03 "
也可以看看
>%[flags] [width]转换
>标志’0′ – 结果将被填零
>宽度2
> Conversion’X’ – 结果格式化为十六进制整数,大写
看看问题的文本,也可能是这是要求:
String[] arr = {"-1", "0", "10", "20" };
for (int i = 0; i < arr.length; i++) {
arr[i] = String.format("%02x", Byte.parseByte(arr[i]));
}
System.out.println(java.util.Arrays.toString(arr));
// prints "[ff, 00, 0a, 14]"
这里的几个答案使用Integer.toHexString(int);这是可行的,但有一些注意事项。因为参数是一个int,所以对字节参数执行扩展的原语转换,这涉及符号扩展。
byte b = -1;
System.out.println(Integer.toHexString(b));
// prints "ffffffff"
由Java签名的8位字节被符号扩展为32位int。为了有效地撤消这个符号扩展,可以用0xFF掩码字节。
byte b = -1;
System.out.println(Integer.toHexString(b & 0xFF));
// prints "ff"
使用toHexString的另一个问题是它不用零填充:
byte b = 10;
System.out.println(Integer.toHexString(b & 0xFF));
// prints "a"
这两个因素结合起来应该使String.format解决方案更可取。
参考文献
>对于字节,从-128到127(含)