byte转换为十六进制时,Integer.toHexString需要&FF的原因

查看如下代码:
        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
 
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,这样转换出来就是正确的了.
posted @ 2015-08-21 11:23  cvbaka  阅读(1181)  评论(0编辑  收藏  举报