查看如下代码:
String mac_no_ff = ""; for (int i = 0; i < 6; i++) { mac += Integer.toHexString(card[i] & 0xff).toUpperCase(); mac_no_ff += Integer.toHexString(card[i]).toUpperCase(); } System.out.println(mac); System.out.println(mac_no_ff);
这个是输出
286ED488C8C3
286EFFFFFFD4FFFFFF88FFFFFFC8FFFFFFC3
286EFFFFFFD4FFFFFF88FFFFFFC8FFFFFFC3
28正常转换,
6E转换后多了一串FF
这是因为Integer.toHexString()的接收参数是int,不是byte,于是运算是会先把byte强制转换为int
由于java中强制转换是保持值不变,而在计算机中数都是用补码表示的,java中int是32位4个byte, 正数补码是正数本身,这样不会有问题,强转为32位时前面24位会填充0,
而负数的补码是"将其对应正数二进制表示所有位取反(包括符号位,0变1,1变0)后加1",
于是32位的0x00 00 00 80(0000 ... 0000 1000 0000)补码是0xFF FF FF 80(1111 ... 1111 1000 0000),前面是填充的1
所以Integer.toHexString()后就会变成前面多了一串F
所以要得到正确的结果,需要用 Integer.toHexString(card[i] & 0xff),这样会只取最后8位(1byte=8位二进制),前面都置0,这样转换出来就是正确的了.