public static String bytes2hex(byte[] bytes) {
StringBuilder sb = new StringBuilder();
String tmp;
sb.append("[");
for (byte b : bytes) {
// 将每个字节与0xFF进行与运算,然后转化为10进制,然后借助于Integer再转化为16进制
tmp = Integer.toHexString(0xFF & b);
if (tmp.length() == 1) {
tmp = "0" + tmp;//只有一位的前面补个0
}
sb.append(tmp).append(" ");//每个字节用空格断开
}
sb.delete(sb.length() - 1, sb.length());//删除最后一个字节后面对于的空格
sb.append("]");
return sb.toString();
}
实现思路
将byte数组拼接成字符串,然后打印
实现过程
遍历byte数组,每个byte转换成16进制的Int
Integer.toHexString(0xFF & b);
使用0xFF和byte做逻辑与,是为了去除byte中的多余部分
对于小于16(16进制中的个位数),用0补齐,这样可以使打印出来的数据长度一致
toHexString说明
以16为底的无符号整数形式返回整数参数的字符串表示形式。
如果参数为负数,则无符号整数值为参数加2^32;否则,它等于论点。此值被转换为十六进制(以16为底)的ASCII数字字符串,没有额外的前导0。
可以通过调用Integer.parseUnsignedInt(s,16)从返回的字符串s中恢复参数的值。
如果无符号幅值为零,则用单个零字符“0”(“\u0030”)表示;否则,无符号幅度表示的第一个字符将不是零字符。以下字符用作十六进制数字:
0123456789bcdef
这些是字符“\u0030”到“\u0039”和“\u0061”到“\u0066”。如果需要大写字母,则可以对结果调用String.toUpperCase()方法:
Integer.toHexString(n).toUpperCase()
参数:i–要转换为字符串的整数。
退货:由十六进制(以16为底)的参数表示的无符号整数值的字符串表示。
自:JDK1.0.2
也可以使用parseUnsignedInt(String s, int radix)方法来转16进制
parseUnsignedInt
将字符串参数解析为第二个参数指定基数的无符号整数。无符号整数将通常与负数相关的值映射为大于MAX_VALUE的正数。字符串中的字符都必须是指定基数的数字(由Character.digh(char,int)是否返回非负值决定),但第一个字符可以是ASCII加号“+”(“\u002B”)。返回得到的整数值。
如果发生以下任何情况,将引发NumberFormatException类型的异常:
第一个参数为null或是长度为零的字符串。
基数小于Character.MIN_radix或大于Character.MAX_radix。
字符串中的任何字符都不是指定基数的数字,但第一个字符可以是加号“+”(“\u002B”),前提是字符串长度大于1。
字符串表示的值大于最大的无符号整数2^32-1。